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PHP 是 比较 普及 的 互联 网 开发 语言 之 一 。 本 书 按 新 手 从 入 门 到 精通 的 
学 习 过 程 ， 从 实际 的 应 用 出 发 详细 介绍 了 PHP 的 脚本 语言 基础 、 开 发 运行 
环境 以 及 各 种 常用 动态 功能 系统 的 开发 。 全 书 共 10 章 ， 内 容 分 为 理论 部 分 
和 实战 部 分 ， 由 浅 入 深 地 介绍 了 PHP 以 及 相关 技术 ， 通 过 大 量 实际 项 目的 
案例 ， 详 尽 地 讲解 了 PHP 的 技术 要 点 和 开发 过 程 ， 精 选 动态 功能 模块 实 
例 ， 通 过 实例 的 讲解 来 让 读者 理解 PHP+MySQL 的 动态 开发 方法 。 全 书包 
括 用 户 管理 系统 、 新 闻 发 布 系统 、 留 言 板 管理 系统 、 投 票 管理 系统 、BBS 
论坛 管理 系统 和 网 上 购物 系统 等 6 PRERA 

本 书 内 容 丰 富 ， 实 用 性 和 操作 性 强 ， 适 合 学 习 PHP-MySQL-Dream- 
weaver 动态 网 页 制作 的 初级 读者 ， 也 适合 作为 高 等 院 校 本 、 专 科 各 专业 动态 
网 页 制作 课程 的 教材 ， 还 可 以 作为 网 页 设计 与 制作 爱好 者 的 自学 参考 书 。 
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PHP 是 最 为 流行 的 Web 编程 语言 之 一 ， 具 有 开源 和 免费 的 独特 优势 。MySQL 是 一 个 广 
受 欢 迎 的 中 型 关系 数据 库 管 理 系统 ， 它 免费 、 快 速 、 跨 平台， 并 且 文 持 多 线程 、 多 用 户 、 重 
负载 的 性 能 要 求 。 使 用 PHP+MySQL 进行 Web 应 用 系统 开发 是 一 种 非常 理想 的 选择 。 

与 其 他 相 类 似 的 计算 机 图 书 相 比 ， 本 书 具 有 以 下 几 点 特色 : 

Dw 内 容 选 编 售 明 扼 要 

一 般 的 PHP 书籍 会 介绍 很 多 的 理论 知识 ， 但 本 书 选 编 内 容 人 简明 扼 要 ， 适 合 初 学 者 学 习 
使 用 。 介 绍 PHP+MySQL 的 基础 知识 时 ， 利 用 每 一 布 介绍 一 个 知识 点 并 同步 配 以 实例 加 以 理 
解 应 用 。 全 书 主题 鲜明 、 要 点 明确 ， 介 绍 了 制作 网 页 的 技巧 和 规范 ， 可 以 让 读者 快速 学 会 使 
用 Dreamweaver CS4 按照 网 页 规范 进行 网 页 制作 。 

ow 从 入 门 到 高 手 导 问 清 晰 

书 中 的 所 有 实例 均 出 自作 者 多 年 来 的 商业 应 用 实例 ， 如 果 是 初学 者 ， 认 真 学 习 第 1 一 3 
章 即 可 以 掌握 平台 的 搭建 、PHP 和 MySQL 配合 开发 的 基础 知识 。 第 4~6 mei 
Dreamweaver 的 集成 动态 功能 ， 快 速 掌 握 在 Dreamweaver 中 开发 PHP 动态 系统 的 功能 。 第 
7 一 10 FAJFI PHP 代码 实现 动态 系统 的 开发 ， 成 为 真正 的 PHP 网 页 开发 高 手 。 每 草 的 
实例 均 符 合 所 讲解 的 知识 点 ， 实 现 了 实践 与 理论 相 结 合 ， 对 于 读者 在 制作 中 的 思路 整理 、 开 
发 创意 会 有 所 帮助 。 

By 超 值 赠送 多 媒体 和 素材 光盘 

附送 光盘 中 制作 了 PHP 开发 平台 搭建 的 多 媒体 教学 光盘 ， 同 时 附 有 所 用 网 站 源 代码 及 
素材 ， 是 轻松 掌握 PHP 网 站 开发 的 最 佳 素材 宝典 。 

本 书 详细 介绍 了 PHP 和 MySQL 开发 的 基础 知识 、 技 术 要 点 ， 并 结合 PHP 和 MySQL 
前 述 了 动态 网 站 的 开发 方法 。 全 书 共 分 10 草 ， 各 草 的 详细 内 容 如 下 。 

第 1 草 介 绍 了 有 关 PHP-MySQL 开发 平台 搭建 的 知识 ， 评 细 说 明了 PHP 5.0 的 基础 知 
iM. Apache 服务 器 的 安装 与 配置 、PHP 环境 的 安装 与 配置 、MySQL 数据 库 的 安 钱 与 管理 以 
及 解决 数据 库 中 文 乱码 问题 等 内 容 。 

第 2 AIAS PHP 的 编程 基础 ， 这 是 使 用 Dreamweaver 开发 网 站 的 第 一 步 ， 介 绍 了 在 
Dreamweaver 进行 PHP 开发 平台 的 搭建 、PHP 程序 编写 的 基础 知识 ， 掌 握 PHP 表单 变量 的 
使 用 、PHP 程序 中 常量 、 变 量 、 表 达 式 以 及 函数 的 基础 ， 其 中 要 重点 掌握 PHP 和 MySQL Zt 
据 库 的 操作 。 

第 3 章 介 绍 了 在 Dreamweaver 软件 下 实现 动态 功能 的 开发 基础 操作 ， 重 点 介绍 了 
Dreamweaver 进行 PHP 开发 的 流程 ， 搭 建 PHP 动态 系统 开发 的 平台 ， 检 查 数 据 库 记 录 的 常 
见 操 作 和 编辑 记录 的 常见 操作 。 

第 4 章 介 绍 了 一 个 典型 的 用 户 管理 系统 ， 在 动态 网 站 中 ， 用 户 管理 系统 是 非常 必要 
的 。 通 过 用 户 注册 信息 的 统计 ， 可 以 让 管理 员 了 解 到 网 站 的 访问 情况 ， 通 过 用 户 权 限 的 设 
置 ， 可 以 限制 网 站 页 面 的 访问 权限 。 一 个 用 户 管理 系统 ， 一 般 应 该 具备 用 户 注册 功能 、 资 
料 修改 功能 、 取 回 密码 功能 以 及 用 户 注 销 身 份 等 功能 。 
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第 5 章 着 重 介 绍 了 新 闻 发 布 系 统 的 实现 方法 。 新 闻 发 布 系统 是 动态 网 站 建设 中 经 常用 到 
的 系统 ， 尤 其 是 政府 单位 、 教 育 单位 或 企业 网 站 。 新 闻 发 布 系统 的 作用 就 是 在 网 上 传播 信 
县 ， 通 过 对 新 闻 的 不 断 更 新 ， 让 用 户 及 时 了 解 行业 信息 、 企 业 状 况 。 所 以 新 闻 发 布 系统 中 涉 
及 的 主要 操作 就 是 访问 者 的 新 闻 查 询 功能 和 系统 管理 员 对 新 闻 的 新 增 、 人 修改、 删除 功能 ， 使 
用 PHP 实现 这 些 功能 相对 比较 简单 。 

第 6 章 介 绍 了 留言 板 管理 系统 的 制作 方法 。 留 言 板 可 以 实现 网 站 与 访问 者 之 间 的 沟通 ， 
收集 用 户 意见 和 信息 ， 也 是 网 站 建设 必 不 可 少 的 一 个 重要 系统 。 利 用 留言 析 ， 可 以 为 访问 人 
员 提 供 发 言 的 机 会 ， 让 他 们 及 时 、 准 确 地 发 表 目 己 的 观点 。 这 些 观点 被 保留 在 服务 器 上 的 数 
据 库 中 ， 而 且 可 以 被 任何 一 个 访问 站 点 的 人 看 到 。 

第 7 章 介 绍 了 投票 管理 系统 的 开发 方法 。 一 个 投票 管理 系统 大 体 可 分 为 3 个 模块 : Xe 
票 模 块 、 选 票 处 理 模 块 以 及 结果 显示 模块 。 投 票 管理 系统 首先 给 出 选票 选 题 ， 即 供 投 票 者 
选择 的 表单 对 象 ， 当 投票 者 单 击 选 择 投 票 按 钮 后 ， 选 票 处 理 模 块 激活 ， 对 服务 器 传送 过 来 的 
数据 做 出 相应 的 处 理 ， 先 判断 用 户 选 择 的 是 哪 一 项 ， 把 相应 字段 的 值 加 1 ， 然 后 对 数据 进行 
更 新 ， 最 后 将 结果 显示 出 来 。 

第 8 ANMAT BBS 论坛 管理 系统 的 开发 。 将 学 习 使 用 PHP 实现 BBS 论坛 的 开发 方 
ik. BBS 论坛 通常 按 不 同 的 主题 划分 为 很 多 版 块 ， 按 照 版 块 或 者 栏目 的 不 同 ， 可 以 由 管理 
员 设 立 不 同 的 版 主 ， 版 主 可 以 对 上 自己 的 栏目 或 版 块 进行 删除 、 修 改 或 者 锁定 等 操作 。 

第 9 章 制 作 了 一 个 电子 商务 网 站 的 表 台 开发 方法 。 主 要 介绍 使 用 PHP 进行 网 上 购物 系 
统 前 台 开 发 的 方法 ， 系 统 地 介绍 了 网 上 购物 系统 的 设计 。 数 据 库 的 规划 以 及 常用 的 儿 个 功能 
模块 前 人 台 的 开发 。 

第 10 章 介 绍 电子 商务 网 站 的 后 人 台 功 能 开发 方法 。 一 个 完善 的 网 上 购物 系统 并 不 只 是 提 
供给 用 户 注 册 、 进 行 购物 等 功能 。 它 还 要 给 网 站 所 有 者 一 个 功能 齐全 的 后 台 管 理 功能 。 网 
站 所 有 者 登录 后 台 管 理 即 可 发 布 新 公告 、 管 理会 员 注 册 、 回 复 留 言 、 维 护 商 品 ， 以 及 管理 
订单 。 

本 书 由 拥有 将 近 10 年 网 站 建设 实战 经 验 的 资深 设计 师 编写 ， 实 现 了 理论 、 实 践 相 结 
合 ， 章 节 安 排 合 理 ， 注 重 了 内 容 的 实用 性 、 可 操作 性 。 本 书 由 环 博 文化 的 陈 益 材 主 编 ， 另 有 
于 和 谷 云 、 官 斯 文 、 气 亮 、 王 炎 光 、 耿 国 续 、 陈 益 红 、 秦 树 德 、 张 铭 运 、 赵 红 、 陈 章 、 于 海 
饮 、 任 霖 参与 了 编写 工作 。 由 于 作者 水 平 有 限 ， 加 之 创作 时 间 仓 促 ， 本 书 疏 漏 之 处 在 所 难 
免 ， 欢 迎 各 位 谈 者 与 专家 批评 指正 。 
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第 四 目 音 ”搭建 PHP 网 站 建设 平台 


PHP 是 一 项 很 有 前 途 的 站 点 动态 网 页 技术 ， 有 是 最 普及 、 应 用 最 广泛 的 Web 开发 语言 之 一 ， 其 


独特 的 语法 混合 了 C Java, Per 以 及 PHP. 目 创 的 新 的 语法 。 它 具有 开放 的 源 代 码 和 多 种 数据 库 
的 文 持 ， 并 且 文 持 器 平台 的 操作 和 面 问 对 象 的 编程 ， 而 且 是 完全 免费 的 。 掌 氛 好 这 个 技术 的 开 友 
也 并 不 困难 。 在 学 习 实 际 的 网 页 程序 编写 之 前 ， 上 自 要 的 就 是 利用 目 己 的 操作 系统 搭建 一 个 适合 
PHP 开发 的 操作 平台 。 现 在 的 操作 系统 只 要 是 Windows XP, Windows 7 等 ， 从 操作 角度 上 来 说 ， 
在 这 几 个 操作 平台 搭建 PHP 只 需 使 用 Apache (或 者 IS 因特网 信息 服务 系统 ) 十 Dreamweaver 
-MySQL 即 可 以 配置 出 来 。 由 于 Windows XP 操作 系统 比较 普及 ， 本 章 束 将 讲解 如 何在 Windows 
XP 中 进行 PHP 操作 平台 的 配置 。 


sa MA ATJE) i5 i 


HRF jA TARA: 


(—7 PHP 5.0 的 基础 知识 

© Apache 服务 器 的 安装 与 配置 
(7 PHP 环境 的 安装 与 配置 

/ c MySQL 数据 库 的 安装 与 管理 
O 解决 数据 库 中 文 乱码 问题 
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-Section - 
PHP 基 础 知识 


PHP 是 一 种 多 用 途 脚 本 语言 ， 尤 其 适合 于 Web 应 用 程序 开发 。 利 用 PHP 强大 的 扩展 
性 ， 可 以 在 服务 并 连接 Java 应 用 程序 ， 还 可 以 与 .NET 建立 有 效 的 沟通 其 全 更 广阔 的 扩展 ， 
从 而 可 以 建立 一 个 强大 的 环境 ， 以 充分 利用 现 有 的 和 其 他 技术 开发 的 人 资源。 同时， 开源 和 路 
平台 的 特性 使 得 使 用 PHP 架构 能 够 快速 、 融 效 地 开 肥 出 可 移植 的 、 跨 平台 的 、 上 共有 强大 功 
能 的 企业 级 Web 应 用 程序 。 


«LL PHP 5.0 特性 | 


PHP 是 超 文本 预 处 理 语言 (Hypertext Preprocessor) HJHX 43. Pr HTML PX 
的 语言 。 它 与 微软 的 ASP HU. SERERE MAI. WA HTML 文档 的 脚本 语言 ， 
语言 的 风格 又 类 似 于 C 语言 ， 现 在 被 很 多 的 网 站 编程 人 员 广 泛 地 应 用 。 

与 其 他 的 编程 语言 做 出 的 动态 页 面相 比 ，PHP 是 将 程序 仍 入 到 HTML 文档 中 去 执行 ， 
执行 效率 比 完全 生成 HTML 标记 的 CGI Zimt. 5l HTML 文档 的 脚本 语言 
JavaScript 相 比 ，PHP 在 服务 器 端 执行 ， 充 分 利用 了 服务 器 的 性 能 。PHP 执行 引擎 还 会 将 用 
户 经 党 访问 的 PHP 程序 驻 留 在 内 存 中 ， 其 他 用 户 再 一 次 访问 这 个 程序 时 就 不 需要 重新 编译 
程序 ， 只 要 直接 执行 内 存 中 的 代码 就 可 以 ， 这 也 是 PHP 高 效率 的 体现 之 一 。 图 1-1 所 示 为 
PHP 的 运行 模式 。PHP 还 具有 非常 强大 的 功能 ， 所 有 的 CGI 或 者 JavaScript 的 功能 PHP 都 
能 实现 ， 而 且 文 持 儿 乎 所 有 流行 的 数据 库 以 及 操作 系统 。 


c 


[o] Jh e P ang 


Apache 网 站 服务 器 MySQL 数 据 库 服务 器 


« s 


图 1-1 PHP 运行 模式 


PHP 最 初 只 是 用 Pen 语言 编写 的 简单 的 程序 ， 用 来 统计 自己 网 站 的 访问 量 。 后 来 又 
用 C 语言 重新 编写， 增加 了 可 以 访问 数据 库 等 功能 ， 并 在 1995 年 发 布 了 PHP 1.0. 2004 


第 1 音 CT 


*E 7 H 13 H PHP 5.0 正式 版 本 的 发 布 ， 标 志 着 一 个 全 新 的 PHP 时 代 的 到 来 。 它 的 核心 是 

第 二 代 Zend 引擎 ， 并 引入 了 对 全 新 的 PECL 模块 的 支持 。 在 不 断 更 新 的 同时 ，PHP 5.0 
依然 保留 了 对 旧 PHP 4.0 程序 的 兼容 。 随 着 MySQL 数据 库 的 发 展 ，PHP 5.0 还 绑 定 了 新 

的 MySQL 扩展 模块 ， 提 供 了 一 些 更 加 有 效 的 方法 和 实用 工具 用 于 处 理 数据 库 操作 。PHP O) 
5.0 添加 了 面 癌 对 象 的 PDO (PHP Data Objects) 模块 ， 提 供 了 男 外 一 种 数据 库 操作 的 方 

案 ， 统 一 数据 库 操 作 的 API. 537b, PHP 5.0 中 还 改进 了 创建 动态 图 片 的 功能 ， 目 前 能 够 
支持 多 种 图 片 格式 (如 PNG, GIF, TIF, JPEG 等 )。PHP 5.0 已 经 内 置 了 对 GD2 FERE 

持 ， 因 此 安装 GD2 库 〈 主 要 指 UNIX 系统 中 ) 也 不 再 是 件 难事 ， 这 使 得 处 理 图 像 十 分 简 
单 和 高 效 。 

PHP 5.0 还 增加 了 只 有 成 熟 的 编程 语言 体系 结构 中 才 有 的 一 些 特性 ， 如 下 面 列 出 的 这 
些 特性 。 

(1) 增加 的 面向 对 象 能 力 。PHP 5.0 的 最 大 特点 是 引入 了 面向 对 象 的 全 部 机 制 ， 并 且 保 
留 了 问 下 的 兼容 性 。 程 序 员 不 必 再 编写 缺乏 功能 性 的 类 ， 并 旦 能 够 以 多 种 方法 实现 类 的 保 
护 。 另 外 ， 在 对 象 的 集成 等 方面 也 不 再 存在 问题 。 使 用 PHP 5.0 引进 的 类 型 提示 和 异常 处 理 
机 制 ， 能 更 有 效 地 处 理 和 避免 错误 的 发 生 。PHP 5.0 增加 了 很 多 功能 ， 例 如 显 式 构造 函数 和 
析 构 函数 、 对 象 克 隆 、 类 抽象 、 变 量 作用 域 和 接口 等 。 

(2) try/catch 卉 第 处 理 。 从 PHP 5.0 开始 支持 寞 党 处理。 在 许多 语言 中 ， 如 C++、 Cf. 
Python 和 Java 等 ， 异 滑 处 理 长 期 以 来 一 直 都 是 错误 管理 方面 的 中 流 研 柱 ， 为 建立 标准 化 的 
错误 报告 逻辑 提供 了 一 种 绝 佳 的 方法 。 

(3) 字符 串 处 理 。 之 前 版 本 的 PHP 默认 将 字符 串 看 做 数组 ， 这 也 反映 了 PHP 原先 的 数 
据 类 型 观点 不 够 严密 。 这 种 策略 在 版 本 5.0 中 有 所 调整 ， 引 入 了 一 种 专门 的 字符 串 偏 移 量 
(offset) 语法 ， 而 之 前 的 方法 已 经 废弃 不 用 。 

(4) XML 和 Web 服务 支持 。 现 在 的 XML 支持 建立 在 libxml2 库 基 础 上 ， 并 引入 一 
个 很 新 并 且 非 常 有 前 途 的 扩展 包 来 解析 和 处 理 XML: SimpleXML。 此 外 ，PHP 5.0 还 支 
持 SOAP 扩展 。 

(5) 对 SQLite 的 内 置 文 持 。PHP 5.0 为 功能 强大 、 人 简洁 的 SQLite 数据 库 服务 器 
Chttp:/www.sglite.org) 提供 了 文 持 。 如 果 开 发 人 员 需 要 使 用 一 些 只 有 重量 级 数据 库 产 品 中 才 
有 的 特性 ， 同 时 不 希望 带 来 相应 的 管理 开销 ，SQLite 则 是 一 个 很 好 的 解决 方案 。 


| PHP 开 发 环境 


在 开始 学 习 PHP 之 前 ， 首 先 需要 配置 PHP 的 运行 环境 。PHP 的 运行 环境 需要 两 个 软件 
的 文 持 : 一 个 是 PHP 运行 的 Web 服务 器 Apache， 而 在 具体 安装 Apache 服务 器 之 前 首先 要 
在 运行 的 系统 上 安装 支持 Apache 服务 器 的 Java 2 SDK; 另 一 个 是 PHP 运行 时 需要 加 载 的 主 
要 软件 包 ， 该 软件 包 主 要 是 解释 执行 PHP 页 面 的 脚本 程序 ， 如 解释 PHP 页 面 的 函数 。 本 书 
主要 介绍 Windows 操作 系统 下 使 用 Apache+PHP 配置 环境 的 方法 。 

PHP 开发 运行 环境 的 需求 如 图 1-2 PTR. 


PHP+ 
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第 一 步 : 安装 Apache 服 务 器 


qi b. 安装 配置 PHP 


第 三 步 : 安装 配置 MySQL 数 据 库 | 


第 四 步 ， 管理 数据 库 ， 解 诀 中 文 乱码 
图 1-2 PHP 环境 配置 步骤 


Apache 服 务 天 的 安 表 


首先 就 是 PHP 网 页 所 需 的 网 站 服务 器 (Web Server) 软 件 Apache 的 安装 与 设 定 。Apache 
网 站 服务 器 的 主要 工作 在 于 编译 PHP 网 页 ， 并 回 传 编译 后 的 PHP 网 页 至 使 用 者 计算 机 的 浏 
Warko Xem YE Apache 的 方法 说 明 如 下 。 


' Apache 简 介 


HM PHP 发 布 之 后 ， 推 出 了 各 式 各 样 的 PHP 引擎 ， 最 为 经 典 的 配置 束 是 使 用 Apache 服务 
fro Apache 是 一 种 开源 的 HTTP 服务 器 软件 ， 可 以 在 包括 UNIX. Linux 以 及 Windows 在 内 的 
大 多 数 主 流 计 算 机 操作 系统 中 运行 ， 由 于 其 文 持 多 平台 并 具有 民 好 的 安全 性 而 被 广泛 使 用 。 

Apache 作为 常 驻 的 后 台 任 务 运行 ， 在 UNIX 系统 中 为 守候 进程 (Daemon) ， 在 
Windows 系统 中 为 服务 (Service) 。 由 于 Apache 服务 器 的 启动 阶段 比较 耗费 时 间 和 资源 ， 
因此 它 一 般 在 操作 系统 局 动 时 被 司 动 并 一 直 运 行 。 

Apache 的 运行 分 为 启动 阶段 和 运行 阶段 。 启 动 阶段 时 ，Apache 以 特权 用 户 root 启动 ， 
进行 解析 配置 文件 、 加 载 模块 和 初始 化 一 些 系统 资源 (例如 日 志文 件 、 共 享 内 存 段 、 数 据 库 
连接 ) 等 操作 。 处 于 运行 阶段 时 ，Apache 放弃 特权 用 户 级 别 ， 使 用 非特 权 用 户 来 接收 和 处 
理 网 络 中 用 户 的 服务 请 求 。 这 种 基本 安全 机 制 可 以 阻止 Apache 中 由 于 一 个 人 简单 软件 错误 
(也 可 能 是 模块 或 脚本 ) 而 导致 的 严重 系统 安全 漏洞 ， 例 如 微软 的 IIS 就 曾 遭 受 “ 红 色 代 人 码 
(Code Red) ”和 “ 尼 姆 达 (Nimda) ”等 恶意 代码 的 游 出 攻击 。 

Apache 的 主 配置 文件 通常 为 httpd.conf。 但 是 由 于 这 种 命名 方式 为 一 般 惯 例 ， 并 非 强 制 
要 求 ， 因 此 对 于 提供 rpm 或 者 deb 包 的 第 三 方 ，Apache 发 行 版 本 可 能 使 用 不 同 的 命名 机 制 。 
另外 ，httpd.conf 文件 可 能 是 单一 文件 ， 也 可 能 是 通过 使 用 Include 指令 包含 不 同 配置 文件 的 
多 个 文件 集合 ， 有 些 发 行 版 本 的 配置 非常 复杂 。httpd.conf 文件 是 一 个 文本 文件 ， 在 系统 局 
动 时 被 未 行 解析 。 访 文件 由 指令 、 容 右 和 注释 组 成 。 配 置 文件 内 允许 有 空 行 和 空格 ， 它 们 在 
解析 时 被 忽略 不 计 。 
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下 载 Apache 软 件 


download.cgi 下 载 Apache 的 最 新版 本 。 


47M Apache 网 页 服务 器 的 首要 工作 便 是 到 Apache 的 官方 网 站 http://httpd.apache.org/ > 


下 载 的 步骤 如 下 。 
(1) 打开 下 浏览 
官方 网 站 ， 如 图 1-3 所 示 。 
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在 网 址 列 输入 http://httpd.apache.org/download.cgi 链接 至 Apache 的 
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Downloading the Apache HTTP Server 
Tre the [mies below bs downland the Apache HTTP Server Eom one af sur mirerz. Yea mart verify the inteenty af the 
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(25 在 这 个 页 面 中 有 许多 的 下 载 选 项 ， 


[ RUIT 


1-3 打开 Apache 官方 网 站 


单 击 选择 页 面 上 的 “httpd-2.2.19-win32-x86- 


no_sslmsi” 文 字 ， 下 载 Apache 的 目 动 安装 程序 ， 如 图 1-4 所 示 。 
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. Was? herida, OptnSSL 0.3. Se (MSI Installer): Hapd-2 wn32-x96-openss- 
b 9 Ar ma [PGP] [MD5] [SHA t] 
. Noire Binary apache 22 19.nemware zip [PGP] [MD5] [SHA 1] 
Coher fioc * 
[ Bar 


1-4. 选择 相应 的 文件 下 载 
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说 明 : 
本 书 所 下 载 的 是 编写 此 书 时 的 最 新 版 本 ， 由 于 Apache 经 常 更 新 版 本 ， 读 者 可 能 会 下 载 
到 不 同 的 最 新 版 本 ， 这 不 会 影响 后 面 的 操作 与 设置 。 


1.2.3 m Apachelll 55 8& E 


完成 下 载 Apache 的 安装 程序 后 ， 双 击 下 载 的 可 执行 安 闭 文件 〈 在 光盘 中 system. 文件 夹 
下 也 有 下 载 的 安装 文件 )， 如 图 1-5 所 示 。 


TF AmE SEV 收藏 IAM 大助 0 
Q RB - O $ PORR ba m 
地 址 0) Ø D: system " 


文件 和 文件 来 任务 


CJ ARAR 
Q 将 这 个 文件 到 发 到 


共享 此 文件 夹 
z Apache-2. 2 19-w ie" MylManagerlite.exe  mysqgl-5.5.13-win3... php-5.2.1T-Win32-... 
x8b5-no ssl.m 


aa 本 地 磁盘 QD 
O 我 的 文档 
p 共享 文档 
3 我 的 电脑 
篇 网 上 邻居 


66.2 MB 时 我 的 电脑 
图 1-5 ”选择 文件 安装 
装 的 步骤 如 下 。 
n JFARZEXB. Apache 安 闭 精 灵 会 提示 将 安装 Apache 服务 右 ， 并 有 警告 信息 ， 如 
图 1-6 所 示 。 


i Apache HITE Server 2.2 — Installation Wizard 


Welcome to the Installation Wizard for 
Apache HTTP Server 2.2.19 


The Installation Wizard will install Apache HTTP Server 2.2.19 
an your computer, To continue, click Next. 


WARMING: This program is protected by copyright law and 
international treaties, 


图 1-6 开始 安装 
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(2) S íi Wet» | 按钮 ， 继 续 安 装 的 程序 。 请 选择 “I accept the terms in the license 
agreement” 同 意 合约 的 授权 ， 进 行 继续 安装 ， 如 图 1-7 所 示 。 


im Ápache HTIE Server 2.2 — Installation Wizard 


License Agreement | © 


Please read the Following license agreement carefully. 


Apache License 
Version 2.0, January 2004 
http://www.apache.org/licenses/ 
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 


1. Definitians. 


"License" shall mean the terms and canditions far use, repraductian, and 
distribution as defined by Sections 1 through 98 ofthis document. 


($5 I accept the terms in Ehe license agreement 


(OI do not accept the terms in the license agreement 


图 1-7 同意 安装 


(3) 单 击 Mets 按钮， 继续 安装 程序 ， 打 开 “Read This First CHAAR)” XNE, 
如 图 1-8 所 示 。 


im Ápache HITP Server 2.4 — Installation Wizard 


Read This First 


Read this Before Running Apache on Windows, 


Apache HTTP Server 


What iz it? 

The Apache HTTP Server is a powerful and flexible HTTPH.1 compliant web server. 
Originally designed as a repnlacementfarthe MCSA HTTP Server, it has grown to be 
the mast popular web server an the Internet. As a project af the Apache Software 
Foundation, the developers aim ta collaboratively develop and maintain a robust, 
commercial-grade, standards-based server with freely available source code. 


The Latest Version 


Details af the latest versian can he found an the Apache HTTP server project page 
under: 


http: httpd.apache.ara 


"t 
DT---.-..---..Ll-4:-.- 一 一 


图 1-8 “Read This First (预览 内 容 )” 对 话 框 


(4) Æ “Read This First (预览 内 容 ，)” 对 话 框 中 主要 是 介绍 Apache HTTP Server 


(Apache 网 页 服务 器 ) 的 一 些 基 础 知识 ， 初 次 使 用 的 读者 可 以 认真 了 解 一 下 ， 以 方便 进一步 
JEH o Hub met INE 打开 “Server Information (服务 器 信息 )” 对 话 框 ， 自 行 设 定 服 
务 器 和 域名 名 称 ， 并 要 输入 管理 员 的 联系 邮箱 ， 如 图 1-9 所 示 。 
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im Apache HITP Server 2.2 一 Installation Wizard 


Server Information 


Please enter vour server's information, 


Metwork Domain (e.g. somenet. com} 
Imyserver 


Server Mame (e.g. wiww,somenet,com): 


Imyserver 


&drministratar's Email Address (e.g. webmaskerisomenet.com): 


|designemt? 163.com 


Install Apache HTTP Server 2.2 programs and shortcuts Far: 


($5 For All Users, on Port 8D, as a Service -- Recommended, 
CO only For Ehe Current User, an Pork 8080, when started Manually, 


| 1-9 “Server Information (服务 器 信息 ) ”对 话 框 


(5) 设 定 完成 后 ， 再 单 击 ， Next > | 按钮 ， 继 续 进 行 下 一 步 的 安装 。 打 开 “Setup Type 
(安装 类 型 )” 对 话 杠 ， 这 里 有 Typical (上 典型) 和 Custom (HEX) 安装 两 个 单 选 项 ， 如 
图 1-10 所 示 。 


im Apache HITP Server 2.2 — Installation Wizard 


Setup Type 
Choose the setup type that best suits your needs. 


Please select a setup type. 


C5 Typical 


Typical program Features will be installed. (Headers and Libraries 
For compiling modules will nat be installed.) 


Choose which program Features you want inskalled and where thew 
will be installed. Recommended For advanced users. 


图 1-10 “Setup Type“〈 安 装 类 型 ) ”对 话 框 


(6) 单 击 选择 Custom (HEX) 单 选 按钮 ， 再 单 击 | Next > | 按钮 ， 打 开 “Custom 
Setup (H ENZ NA)” Hite, WK 1-11 所 示 。 这 里 将 选择 所 有 的 内 容 进行 安装 ， 以 
方便 后 面 PHP 程序 的 开发 应 用 需要 。 由 于 Apache 预 设 的 路 径 有 点 长 ， 为 了 方便 起 见 ， 本 
书 将 安装 路 径 改 成 C:\Apache， 单 击 Change (改变 ) 按钮 ， 将 服务 器 的 安装 路 径 设 置 为 
C:\Apache\. 

CI) 单 击 ，Next WH, IFF “Ready to Install the Program (准备 安装 )” 对 话 框 ， 如 
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图 1-12 所 示 。 


im Apache HIIP Server 2.2 — Installation Wizard 


Custom Setup 


Select the program Features you want installed. 


Click on an icon in the list below to change how a Feature is installed. 


Feature Description 
| This Feature installs the headers 
and libraries required to compile 
and link additional modules. 


| 日 &9-]Apache HTTP Server 2.2.19 


B-E SM aan Runtime 
Build Headers and Libraries 


Er | APR Icony Code Pages 
& » | Apache Documentation 
& » | Apache Service Taskbar Icon This Feature requires 5340KB on 
vour hard drive. 


Install to: 
CilApachel 


EOM 


图 1-11 


(8) 接 下 来 开始 进行 安装 ， 
(9) 安装 完成 后 ， 单 击 | Einish 


“Custom Setup〔 目 定义 安装 内 容 ) ”对 话 框 


Mok 


P d 


Please wait while the Installation Wizard installs Apache HTTP Server 
2.2.19, This may take several minutes. 


ie Apache HITP Server 2.2 一 Installation Wizard 


Installing Apache HTTP Server 2.2.19 


The program Features you selected are being installed. 


Status: 
Copying new Files 
BERRRERRRRRRRRRRARWARRARRMAARMRRANRRRAMNARRMAARMEREN 


图 1-13 ”安装 过 程 


装 与 设 定 就 完成 了 。 


Apache Jl: 25-35 Eh] 4. 


Ready to Install the Program 


The wizard is ready to begin installation. 


Click Install to begin the installation. 


If you want to review or change any of your installation settings, click Back. Click Cancel to 
exit the wizard. 


图 1-12 准备 安装 对 话 框 


法 的 过 程 如 图 1-13 所 示 。 
| 按钮 ， 如 图 1-14 Wr. 


13 Apache HITP Server 2.2 — Installation Wizard 


Installation Wizard Completed 


The Installation Wizard has successfully installed Apache HTTP 
Server 2.2.19, Click Finish to exit the wizard. 


图 1-14 Sim 


Apache 服 务 


JJC Apache 服务 器 后 ， 首 先 要 测试 表面 的 安装 与 设 定 是 耕 成 功 。 由 于 是 在 本 机 
ejes Apache 服务 右 ， 因 此 它 的 HTTP HEHEA TU EST http://localhost. 
首先 打开 正 浏览 器 ， 在 网 址 列 输入 http://localhost， 如 果 能 顺利 开启 如 图 1-15 所 示 的 网 
页 画面 ， 束 表示 Apache 服务 器 服务 成 功 让 5I. 
Apache 服务 器 的 服务 ， 与 PHP 网 页 的 执行 有 很 重要 的 关联 ， 因 此 接 下 来 要 说 明 Apache 
服务 器 的 设 定 与 操作 。 


器 的 操作 j 


— 
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acrosoft Internet Explorer 

xc) (Wc EEN FRA IAT) WMH E 
OD- DRAA PRR wea 6 2-5 

IRIE OO AE) http //1ses1hast/ -Arek wv EJA uv Osud: c 


It works! 


1-15 测试 成 功 页 面 


1. Apache 服务 器 的 启动 

"AXE Apache 服务 器 安装 完成 的 页 面 上 上， 已 经 勾 选 “for All User, on Port 80, as a Service- 
Recommended.” 的 选项 ， 那 么 Apache 整 已 经 日 动 局 动 ， 可 以 在 Windows 工作 列 上 的 系统 图 
bi AH Y "EN. 

WMR Apache 服务 器 保 止 服务 后 要 再 局 动 Apache 服务 器 ， 在 Windows 系统 图 标 中 的 总 
图 标 上 ， 单 击 弹 出 快捷 菜单 ， 再 单 击 选 择 Start (开始 ) 就 可 以 重新 启动 Apache 服务 器 的 
服务 。 

2. Apache 服 务 器 的 停止 

如 果 要 停止 Apache 服务 器 ， 在 Windows 系统 图 标 中 的 : 咏 图 标 上 ， 单 击 弹出 快捷 末 持 ， 
Hifi Stop (停止 ) 束 可 以 停止 Apache 服务 占 的 服务 ， 这 时 
Apache 的 系统 图 标 变 成 咏 ， 如 图 1-16 所 示 。 

3. Apache 服 务 器 的 主 目 录 

正常 情况 下 ，Apache 服务 器 主 目 杂 的 预 设 位 置 在 C:\Program 
Files\Apache Software Foundation\Apache 路 径 下 。 由 于 本 书 将 
Apache 服务 器 安装 在 CNApache 文件 夹 中 ， 因 此 主 目录 也 在 C:\Apache 路 径 下 ， 打 开 的 一 级 
目录 如 图 1-17 所 示 。 


Festart 


1-16 窗口 页 面 


| Xi) mm mao umo IrN-) Won 
GAE- Oo d$ ^x ox D 


xtd HESS 
c3 bikk-- CHE 
g ucxMEWME | 
LCS | ary ar | hide: — — MON ici: 
TEIL 


d pum 


图 1-17 打开 的 文件 夹 目 录 
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Apache 服务 器 各 主 目 录 的 意义 与 用 途 说 明 如 表 1-1 所 示 。 


表 1-1 Apache 文件 说 明 


目录 名称 意义 与 用 途 e 
"m 存放 编译 程序 及 指令 文件 = 
"s 存放 用 于 设置 支持 egi 的 文件 h 
conf 存放 服务 器 结构 档案 ，httpd.conf 文件 是 设置 服务 器 的 主要 文件 
error 存放 运行 出 错时 提示 用 的 文件 
htdocs 存放 运行 成 功 时 显示 的 文件 ， 该 版 本 只 有 简单 的 一 行 字 
icons 存放 服务 器 显示 相应 网 页 的 所 有 图 片 文 件 
include 存放 文 持 服务 器 的 一 些 主要 包含 文件 
lib 存放 Apache 所 需 的 lib 文件 
logs 存放 日 志 档 案 
manual 存放 服务 器 的 模块 功能 文件 
modules 存放 网 页 应 用 程序 的 目录 


4. Apache 服 务 器 的 网 站 目录 

在 Apache 服务 右 中 ， 所 有 PHP 网 页 的 网 站 目录 都 必须 放 到 CApache/htdocs 文件 夹 内 。 例 如 
号 了 一 个 名 为 website 的 PHP 网 站 目录 ， 则 这 个 website 的 网 站 目录 位 置 应 该 放 到 
C:\Apache\htdocs\ 的 文件 夹 中 。 当 然 也 可 以 直接 打开 httpd.conf 文件 ， 找 到 如 图 1-18 所 示 的 位 置 ， 
将 DocumentRoot “C:/Apache/htdocs” 这 一 行 代 码 进行 相应 的 设置 即 可 更 改 为 新 的 网 站 目录 。 


P httpd. conf 一 记事 本 
WED RED BRO SEV 才 助 00 


# DocumentRoot: The directory out of which you vill serve your] 
# documents. By default, all requests are taken from this directory, but 
# symbolic links and aliases may be used to point to other locations. 


DocumentRoot "C:/Rpache/htdocs" 


# Each directory to which Apache has access can be configured with respect 
# to which services and features are allowed and/or disabled in that 

it directory (and its subdirectories). 

Hu 


# First, ve configure the "default" to be a very restrictive set of 
# features. 
H 


<Directory /> 
Options FollowSymLinks 


图 1-18 设置 网 站 文件 位 置 


进行 到 此 ， 已 经 完成 了 PHP 网 页 开发 环境 Apache IKI ari 


PHP 的 安装 与 配置 


接 下 来 的 工作 就 是 设 定 PHP 的 执行 环境 。PHP 的 安装 与 配置 有 多 种 方法 ， 这 里 介绍 使 
用 PHP 官方 提供 的 安装 包 来 进行 安装 的 方法 。 


PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


下 载 PHP 


安装 好 Apache 服务 器 以 后 ， 下 面 开始 安装 PHP. PH 开发 软件 包 是 开发 PHP 程序 的 核 
心 ， 该 软件 包 需 要 从 PHP 官方 网 站 下 载 ， 地 址 为 http:Wwww.php.net。 上 有 目 前 PHP 最 新 的 版 本 
是 2011 Æ 3 H 22 日 发 布 的 PHP5.2.17， 这 里 以 该 版 本 为 例 ， 下 载 的 页 面 如 图 1-19 所 示 。 


Z PHP For Windows: Binaries and sources Releases — Nicrosoft Internet Explorer 


SEO) 编辑 FF) 查看 WW) 收藏 和 IAM $8500 
Q mB - [) |j (9 JO Sek wx 6 e SBL 


ui 


输入 关键 词 搜索 M Eea dE Qs E 


C++ Runtime (x64) installed = Zip [9.97MB] 


Do NOT use YC9 version with shal: 30e2e65e80cec780a42d0b7eb5fedSd42bf20eb4a 
apache.org binaries 

m Installer [20.24MB] 
wC9 versions of Apache can be 
fetched at &pache Lounge. We 
use their binaries to build the 
Apache SAPIs. 


shal: 2145f6adf72ab5faaD67c52163c6b1cil8c47eedd 


a Debug Pack [4.94MB] 
shal: 77lb2587ea0087aa01fcc47d438597elee46e5e4 


Archives VC6 x86 Thread Safe (2011-Mar-22 13:29:30) 


Past releases are available — 
= Zip [10.06MB] 


versions not found there can be shal: 23eicf2f6elbf64585ae92146234085748fcc939 
found at the Museum, 
a Installer [20.41MB] 


shal: p A N MEER 15796f0a390 
a Debug Pack [4.99MB] 
shal: 027c38420ee21c049345b3baea149d083e558a4c 


uj http: //windows. php. net/downloads/releases/php-5.2.1T-Win32-VCB5-x8Bb. msi 


图 1-19 FÆ PHP 的 最 新 安装 版 本 
从 PHP 5.2.10 版 本 开始 (现在 有 PHP 5.2.10 和 PHP5.3 两 个 版 本 )， 有 Non-Thread Safe 


与 Thread Safe 两 种 版 本 的 可 供 选 择 。 这 两 种 版 本 有 何不 同 ， 作 为 使 用 者 来 说 又 应 该 如 何 选 
择 呢 ? 先 从 字面 意思 上 理解 ，Non-Thread Safe 束 是 非 线 程 安 全 ， 在 执行 时 不 进行 线程 
(Thread) 安全 检查 ，Thread Safe 束 是 线程 安全 ， 执 行 时 会 进行 线程 (Thread) 安全 检查 ， 以 
防止 有 新 要 求 束 局 动 狐 线程 的 CGI 执行 方式 耗 尽 系统 资源 。 再 来 看 PHP 的 两 种 执行 方式 : 

ISAPI 和 FastCGI。FastCGI 执行 方式 是 以 单一 线程 来 执行 操作 ， 所 以 不 需要 进行 线程 的 安全 
检查 ， 除 去 线程 安全 检查 的 防护 反而 可 以 提 蜗 执行 效 紊 ， 所 以 ， 如 果 是 以 FastCGI (无 论 拱 
配 IIS6 或 IS7) 执行 PHP ， 部 建议 下 载 、 执 行 Non-Thread Safe 的 PHP (PHP. 的 二 进位 
文档 有 两 种 包装 方式 : msi zip ， 请 下 载 zip 套件 )。 而 线程 安全 检查 正 是 为 ISAPI 方式 的 
PHP 准备 的 ， 因 为 有 许多 PHP 模块 都 不 是 线程 安全 的 ， 所 以 需要 使 用 Thread Safe 的 PHP. 

本 书 是 使 用 Apache 服务 器 ， 所 以 要 选择 VC6 版 本 的 Thread Safe 这 个 PHP 来 安装 。 


安装 PHP 


下 载 后 即 可 以 开始 PHP 的 安 逆 ， 有 具体 的 安 儿 步骤 如 下 。 
CD 双击 下 载 的 文件 php-5.2.17-win32-installermsi〈 在 光盘 中 system. 文件 夹 下 也 有 下 载 
的 安 冯 文 件 )， 弹 出 “Welcome to the PHP 5.2.17 Setup Wizard 〈 欢 迎 安 装 PHP 安装 程序 )” 对 
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WME, WB 1-20 所 示 。 

(2) 单 击 [_nex | 按钮 ， 打 开 “End-User License Agreement (终端 用 户 许可 )” 对 话 框 。 
请 单 击 选择 “Iaccept the terms in the license Agreement” 复 选 按 钮 ， 同 意 合约 的 授权 ， 继 续 进 
41229, WK 1-21 所 示 。 


13 PHP 5.2.17 Setup T PHP 5.2.17 Setup 


End-User License Agreement ue. E 


Welcome to the PHP 5.2.17 Setup Wizard 


Please read the Following license agreement carefully 


The Setup Wizard will install PHP 5.2.17 on your computer. 
Click Next to continue or Cancel to exit the Setup Wizard. 
Please disable any virus detection software you may have 
running during this installation. 


The PHP License, version 3.01 
Copyright (c) 1999 - 2010 The PHP Group. àÀll rights 


Redistribution and use in source and binary forms, 
with or without 
modification, is permitted provided that the 


[7]I accept the terms in the License Agreement 


图 1-20 ”欢迎 安装 界面 图 1-21 同意 安装 
(3) 单 击 [_ wee _ | 按钮 ， 打 开 “Destination Folder (安装 路 径 文 件 )” 对 话 框 时 ， 单 击 
Browse (JV) 按钮 来 更 改 PHP 的 安 北 路 人 笃 ， 这 里 为 “C:\PHP\W 目录 ， 如 图 1-22 所 示 。 
(4) 设置 PHP 安装 路 径 之 后 ， 单 击 [Next ”| 按钮 ， 选 择 安装 Apache 版 本 号 ， 这 里 为 
Apache 2.2x Module， 如 图 1-23 所 示 。 


iŞ PHP 5.2.17 Setup iŞ PHP 5.2.17 Setup 


Destination Folder Web Server Setup 


Click Next to install to the default Folder or click Browse to choose another. Select the Web Server you wish to setup. 


O Apache 1.3.x Module 
O Apache 2.0.x Module 
© Apache 2.2.x Module 
O Apache CGI 

CO IIS ISAPI module 

QO IIS FastCGI 

(II5 CGI 

CONSAPI 

CO Xitami 

CO Sambar Server 

CO NetServe Web Server 
CO Other CGI 

CO Do not setup a web server 


Install PHP 5.2.17 to: 


cnPHPI 


图 1-22 设置 安装 路 任 图 1-23 ”选择 Apache 版 本 号 


(5) 再 单 击 [_ Nex _ | 按钮 ， 选 择 Apache 服务 器 的 安装 路 径 ， 如 图 1-24 所 示 。 

(6) 然后 单 击 [_ Nex | 按钮 ， 打 开 “Choose Items to Install (选择 安装 项 目 )” 对 话 框 ， 
选择 要 安装 的 PHP 组 件 ， 建 议 全 部 选择 安装 ， 设 置 如 图 1-25 Br. 

特别 说 明 : 

在 安装 的 时 候 一 定 要 展开 PHP 的 列 选项 ， 勾 选 MySQL 的 组 件 ， 这 样 才 能 把 PHP 和 
MySQL 数据 库 关联 起 来 ， 以 方便 进一步 的 数据 库 连 接 使 用 . 

CI) 设置 完成 后 单 击 [_Next — | 按钮 ， 打 开 “Ready to install PHP. (准备 安装 )” 对 话 框 ， 
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如 图 1-26 所 示 。 
(8) HAt nta 按钮 开始 安装 PHP， 安 装 的 过 程 会 有 安装 进度 提示 ， 如 图 1-27 
所 示 。 


i PHP 5.2.17 Setup i PHP 5.2.17 Setup 


Apache Configuration Directory Choose Items to Install 


Browse to select the directory containing the Apache Configuration Files (c... Select the way you want features to be installed. 


人 Click the icons in the tree below to change the way features will be installed. 


z Eds" PHP ^ Optional Extras For the PHP Install 


=M Script Executable 


Sr v | Register * ,ph 


|c:\apache' 


Browse... TE — SM Extensions 


Ez | bzip2 This Feature requires OKB on your 
& » | Curl hard drive. It has 2 of 2 

& ~| DBA subfeatures selected. The 

E ~ | dBase z subfeatures require 13MB on your 
hard drive. 


> 


图 1-24 选择 Apache 服务 器 安装 路 径 图 1-25 ”选择 安装 项 目 


ig PHP 5.2.17 Setup i PHP 5.2.17 Setup 


Ready to install PHP 5.2.17 Installing PHP 5.2.17 


Click Install to begin the installation. Click Back ko review or change any of your Please wakt while the Setup Wizard installs PHP 5.2.17, 
installation settings. Click Cancel to exit the wizard. 


Status: 


aono LI NN 


Cancel 


图 1-26 准备 安装 对 话 框 图 1-27 安装 过 程 


(9) 安 状 完 成 后 会 显示 完成 对 话 框 ， 提 示 成 功 安 灾 了 PHP 软件 包 ， 单 击 Finish 按钮 完 
成 安装 ， 如 图 1-28 所 示 。 

C100 这 是 最 关键 的 一 步 ， 需 要 将 安装 后 的 CAPHPVxt 文件 夹 下 的 驱动 文件 都 复制 到 
CANWINDOWSNsystem32 Fh. 

如 果 读 者 在 PHP 官方 网 站 下 载 的 PHP PFE SKRIET E, JA TEBCBLN 
需要 设置 环境 变量 。 具 体 设置 环境 变量 的 方法 如 下 : 首先 将 PHP 包 解 压 到 指定 文件 夹 中 作 
为 PHP 的 根 目 录 ， 例 如 “CNPHP” 目 录 中 ， 然 后 再 配置 Apache 运行 时 需要 加 载 的 
php5apache2 2.dll 文件 。 方 法 是 将 PHP 的 安装 路 径 退 加 到 Windows 系统 中 Path 路 径 的 下 
面 ， 右 击 “ 我 的 电脑 >， 选择 “属性 ”命令 ， 在 弹出 的 “系统 属性 ”对 话 框 中 切换 到 “ 高 
级 ”选项 卡 ， 青 蛙 击 “环境 变量 ”按钮 ， 打 开 “ 环 境 变 量 ” 对 话 框 ， 从 “系统 变量 ”列表 中 
找到 Path 路 径 ， 单 击 “ 编 辑 ” 按 钮 后 ， 在 弹出 对 话 框 的 “变量 值 ” 文 本 框 中 将 C: PHP 追加 
到 路 径 中 ， 如 图 1-29 所 示 。 


编辑 系统 变星 


Click the Finish button to exit the Setup Wizard. 


SI NSystemRootWAsystem32; Syst 


AERE (S) 


变量 

ComSpec C: WINDOWS*system32^emd. exe 
FP NO HOST C... T 
NUMBER OF PR... 

üs T" 

Path Es Wei c: : \HINDOWS Vsysten32; E: m * 
DATuUTVT 


Back. Cancel 


图 1-28 ”完成 安装 图 1-29 “编辑 系统 变量 ”对 话 框 设置 


eI 配置 Apache 支 持 PHP 


安装 完成 PHP 后 ， 并 不 能 直接 在 Apache 里 运行 PHP 文件 ， 还 要 进一步 配置 Apache 才 
可 以 支持 PHP 的 运行 ， 配 置 的 方法 很 简单 ， 方 法 如 下 。 
(1) 进入 Apache 服务 器 的 安 北 文 件 夹 ， 如 图 1-30 所 示 。 
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图 1-30 进入 Apache 服务 器 的 安装 过 文件 夹 


(2) 双击 进入 conf 目录 ， 打 开 httpd.conf 文件 ， 在 文件 的 最 下 方 增加 下 列 3 行内 容 ， 如 
图 1-31 所 示 : 
LoadModule php5 module "CAPHPWphp5apache2 2.dll" 
AddType application/x-httpd-php .php 
PHPIniDir "C:\php" 
该 段 代 码 中 ， 第 1 行 表示 要 加 载 的 模块 在 哪个 位 置 存 储 ; 
第 2 行 表 示 将 一 个 MIME 类 型 绑 定 到 菏 个 或 条 坚 扩展 名 。.php 只 是 一 种 扩展 名 ， 这 里 


7PHP-^ 


可 以 设 定 为 .html、.php2 45; 


Tr S48) Ato) 查看 [9) WR500 


u E SSL/TLS) connections 
"Include conf/extra/httpd-ssl.conf 


# Note: The Following must must 
# starting without SSL on e hieten ith - Fem equivalent 
q" but a statically conpiled-in mod ssl 


*ItModule ssl module» 

SSL RandonSeed startup builtin 
SSLRandonSeed connect builtin 
C/VrHnodule» 


oadModule php5 module "C-:XPHPXphp5apache2 2.d11" 
ddType application/x-httpgd-php -php 
HPIniDir "C:Xphp" 


1-31 加 入 支持 PHP 的 代码 
第 3 行 表 示 PHP 押 在 的 初始 化 路 径 。 
此 时 PHP 环境 就 配置 完成 了 。 
(3) 同样 查找 DirectoryIndex 这 个 代码 ， 将 其 后 面 的 代码 改 为 


DirectoryIndex index.php default.php index.html 


表示 默认 访问 站 点 时 打开 的 首页 顺序 是 index.php default.php index.html. 


(SOUL 测试 PHP 环 境 


PHP 软件 包 和 安装 完成 后 ， 束 可 以 在 Apache 中 测试 PHP 环境 是 否 正 确 了 。 下 面 创建 一 个 
PHP 示例 来 测试 ， 该 示例 是 执行 一 个 带 有 PHP 脚本 的 程序 ， 如 果 执 行 成 功 ， 则 证 明 PHP 安 
装 成 功 。 打 开 Apache 下 的 htdocs 目录 〈 这 里 为 C:\Apache\htdocs)， 然 后 使 用 记事 本 创建 一 
个 名 为 test.php 的 文件 ， 再 添加 如 下 代码 到 文件 中 。 


<?php 
phpinfo(); /输出 PHP 环境 信息 


?> 


保存 test.php 文件 ， 然 后 在 IE 浏览 器 的 地 址 栏 中 输入 “http:/localhost/test.php”， WR E 
zs PHP 的 相关 信息 ， 则 证 明 PHP ee 如 图 1-32 SS 否则 安装 失败 。 


System [Wines NT 6647514373C0420 5.1 baid 2600 
EET 


= 


1-32 test.php 页 面 效果 
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PHP 配置 文件 


安装 PHP 后 还 可 以 根据 需要 编辑 php.in; 文件 对 PHP 的 配置 进行 设置 。 下 而 就 对 PHP 
配置 文件 phpini 的 组 织 方式 进行 简要 的 说 明 。 文 件 命 名 为 phpini 的 原因 之 一 是 它 遵 循 许多 
Windows 应 用 程序 中 INI 文件 的 常见 结构 。php.ini 是 一 个 ASCII 文本 文件 ， 并 且 被 分 成 几 个 
不 同名 称 的 部 分 ， 每 一 部 分 包括 与 之 相关 的 各 种 变量 。 

每 一 部 分 类 似 于 如 下 结构 : 


[MySection] 
variablez" value" 


anothervariable-"anothervalue" 


各 部 分 的 名 称 通过 方 括号 “[ ]” 括 起 来 放 在 顶部 ， 然 后 是 任意 数量 的 变量 名 =“ 值 ” 
对 ， 每 一 对 占 单 独 一 行 。 如 来 行 以 分 扎 “;” 开 头 ， 则 表明 该 行 是 注释 语句 。 

在 php.ini 中 允许 或 茶 止 PHP 蕊 能 变 得 非常 简单 ， 上 只 需要 将 相关 语句 注释 而 无 需 删除 ， 
该 语句 就 不 会 家 系统 解析 。 特 别 是 ， 当 而 望 在 一 段 时 间 以 后 重新 打开 东 种 功能 的 时 候 特 别 方 
便 ， 因 为 不 需要 在 配置 文件 中 将 此 行 删除 。 

如 下 面 php.ini 文件 中 的 一 个 片段 : 


$555555555255555555595? 
; Language Options ; 


; Enable the PHP scripting language engine under Apache. 

engine = On 

; Enable compatibility mode with zend engine 1 (PHP 4.x) 

zend.zel compatibility mode = Off 

; Allow the <? tag. | Otherwise, only <?php and <script> tags are recognized. 
; NOTE: Using short tags should be avoided when developing applications or 
; libraries that are meant for redistribution, or deployment on PHP 

; servers which are not under your control, because short tags may not 

; be supported on the target server. For portable, redistributable code, 

; be sure not to use short tags. 

short open tag = Off 

; Allow ASP-style <% 965 tags. 

asp. tags = Off 

; Ihe number of significant digits displayed in floating point numbers. 
precision = 14 


在 这 个 文件 中 可 对 PHP 的 12 个 方面 进行 设置 ， 包 括 : 语言 选项 、 安 全 模式 、 语 法 突出 
显示 、 某 项、 资源 限制 、 错 误 处 理 和 日 志 、 数 据 处 理 、 路 人 径 和 目录 、 文 件 上 传 、Fopen A% 
髓 、 动 态 扩展 和 模块 设置 。php.ini 文件 存放 在 PHP 的 安装 路 径 ， 在 每 次 局 动 PHP 时 都 会 读 
取 。 因 此 ， 在 通过 修改 php.ini 文件 改变 PHP 配置 之 后 ， 需 要 重启 Web 服务 器 以 使 配置 改变 
生效 。 本 书 的 实例 需要 配置 的 对 象 为 


magic quotes gpc = On 


PHP+ 


magic quotes gpc 功能 为 : 是 否 目 动 为 GPC(egebpostcookie) 传 来 的 数据 中 的 \”\”N 加 上 
bz o 

如 果 magic quotes gpc-On. 3xk|lH| 1, PHP ITAMA HJ post. get. cookie 过 来 的 
数据 增加 转 义 字符 “”， 以 确保 这 些 数 据 不 会 引起 程序 ， 特 别 是 数据 库 语 句 因为 特殊 字符 引 
起 的 污染 而 出 现 致命 的 错误 。 

在 magic_quotes_gpc=On WEW F, WRA WAA E Ch MAI C RA 
线 CO 与 NUL (NULL 字符 ) SE AU Eb. KEFEN EMA. MRAN 
项 为 Off， 返 回 0 ,. MARIAH addslashes 这 个 函数 来 为 字符 串 增 加 转 义 。 


和 
| 
a a PCIE 
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安装 与 应 用 MySQL 数 据 库 


网 站 数据 库 束 是 用 来 储存 大 量 的 网 站 数据 以 及 更 狐 任 何 数 据 信 息 变 动 的 ， 也 就 是 说 通过 
数据 库 的 查询、 新 增 、 修 改 与 删除 ， 网 站 信息 也 随即 跟着 变动 。 本 书 末 用 MySQL 作为 网 站 
的 数据 库 ， 可 以 到 MySQL 的 官方 网 站 http:/www.mysql.com 下 载 MySQL 版 本 。 


| MySQL(ÍS ST 


MySQL 是 一 个 真正 的 多 用 户 、 多 线程 SQL 数据 库 服务 器 。SQL “〈 结 构 化 查询 语言 ) 是 
世界 上 最 流行 的 、 标 准 化 的 数据 库 语 言 。MySQL 是 以 一 个 客户 机 /服务 器 结构 实现 ， 由 一 个 
服务 器 守护 程序 mysqld 和 很 多 不 同 的 客户 程序 和 库 组 成 。 

SQL 是 一 种 标准 化 的 语言 ， 它 使 得 存储 、 更 新 和 存 取 信息 更 容易 。 例 如 ， 能 用 SQL 语 
言 为 一 个 网 站 检索 产品 信息 及 存储 顾客 信息 ， 同 时 MySQL 也 允许 用 户 足 够 快 和 灵活 地 存储 
记录 文件 和 网 像 。 

MySQL 的 主要 目标 是 快速 、 健 壮 和 易 用 。MySQL 最 初 被 开发 的 原因 是 因为 需要 一 个 
SQL 服务 器 一 一 它 能 处 理 与 任何 可 不 昂 贯 便 件 平台 上 的 数据 库 在 一 个 数量 级 上 的 大 型 数据 
库 ， 而 且 它 的 速度 更 快 。 自 1996 年 以 来 ， 我 们 一 直 在 使 用 MySQL， 其 环境 有 超过 40 
个 数据 库 ， 包 含 10000 个 表 ， 其 中 500 多 个 表 超 过 700 万 行 ， 这 大 约 有 100GB 的 关键 应 
用 数据 。 

MySQL 建立 的 基础 是 已 用 于 高 要 求 的 生产 环境 多 年 的 一 套 实用 例 程 。 尽 管 MySQL 4j 
在 开发 中 ， 但 它 已 经 提供 了 一 个 丰富 和 极其 有 用 的 功能 集 。 

在 这 里 推荐 使 用 MySQL 的 主要 原因 有 以 下 几 点 。 

D 便宜 (通常 是 免费 )。 

2) 网 络 承载 比较 少 。 

3) 经 过 高 度 最 佳 化 〈HighlyOptimized )。 

4) 应 用 程序 通过 它 做 起 备份 来 比较 简单 。 

5) 为 各 种 不 同 的 数据 格式 提供 弹性 的 接口 。 

6) 较 好 学 且 操 作 人 简单 。 

MySQL 的 优点 有 以 下 几 点 。 
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1. 避免 网 络 阻塞 

针对 多 个 使 用 者 共同 存 取 的 文 持 ，MySQL 内 定 最 大 连接 数 为 100 个 使 用 者。 但 是 ， 即 
使 网 络 上 有 大 量 数 据 往 来 ， 并 不 会 对 查询 最 佳 化 (Query Optimization A £ KEI. 

2. 最 佳 化 

数据 库 结 构 设 计 也 会 影响 到 MySQL 的 执行 效率 ， 例 如 MySQL 并 不 文 持 外 来 键 (Foreign 
Key)， 这 个 缺点 会 影响 到 数据 库 设 计 以 及 网 站 的 效率 。 

对 于 使 用 MySQL 做 数据 库 文 持 的 网 站 ， 应 该 将 重点 放 在 如 何 让 硬盘 存 取 减 少 到 最 低 、 
如 何 让 一 个 或 多 个 CPU 随时 保持 在 高 速 作业 的 状态 ， 以 及 文 持 适当 的 网 络 频 宽 ， 而 非 实际 
上 的 数据 库 设 计 以 及 数据 得 询 状况 。 

3. 多 线程 

MySQL 是 一 个 快速 、 多 线程 (Multithread)、 多 使 用 者 日 功能 强大 的 关系 型 数据 库 官 理 
RA (Relational Database Management System, RDBMS). tiit vi tm- MySQL Žr 
据 库 连接 时 ， 服 务 器 会 产生 一 个 线程 (Thread) 或 一 个 行程 (Process) 来 处 理 这 个 数据 库 连 
接 的 请 求 (Request). 

4. 可 延伸 性 以 及 数据 处 理 能 

MySQL 同时 上 共有 局 度 多 样 性 ， 能 够 提供 给 很 多 不 同 的 使 用 者 接口 ， 包 括 命令 列 、 客 户 剖 操 
作 、 网 页 浏览 器 、 以 及 各 式 各 样 的 程序 语言 接口 ， 例 如 Cer. Perl. Java. PHP 以 及 Python. 

MySQL 可 用 于 UNIX. Windows. OS/2 等 平台 ， 也 束 是 说 它 可 以 用 在 个 人 计算 机 或 者 
是 服务 器 上 。 

5. 便于 学 习 

MySQL 文 持 结 构 化 查询 语言 (Structured Query Laneuage，SQL)， 那 么 精通 数据 库 的 人 
在 一 天 之 内 ， 就 可 以 学 会 MySQL， 对 于 初学 者 来 说 也 非常 容易 上 手 。 


安装 MySQL 数 据 库 


下 载 MySQL 数据 库 的 步骤 如 下 。 
(1) 打开 IE XAS HICE] MySQL 的 官方 网 站 http:/www.mysqlcom， 下 载 MySQL 
数据 库 ， 如 图 1-33 Bron. 


Js ri Pre sd rrzslly AÁrailablr) — Hücrorsft Ënterr x 
meo 


图 1-33 打开 MySQL 主页 
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(2) 打开 主页 之 后 找到 相关 下 载 文 件 ， 本 书 下 载 的 是 MySQL 的 最 新 版 本 《在 光盘 中 
system. 文件 夹 下 也 有 下 载 的 安 关 文 件 )。 下 载 后 双击 安装 程序 mysg1-5.5.13-win32.msi， 打 开 
“Welcome to the MySQL Server 5.5 Setup Wizard”( 欢 迎 开 始 安装) peru, Ak 1-34 所 示 。 

(3) MySQL 安装 精灵 会 显示 欢迎 界面 ， 并 提示 安装 的 版 本 ， 单 击 L_next_ | 按钮 继续 
安装 程序 ， 打 开 “End-User License Agreement 〈 终 端 用 户 许可 )” 对 话 框 。 请 单 击 选择 “I 
accept the terms in the license Agreement” 复 选 按钮 ， 同 意 合约 的 授权 ， 进 行 继续 安 朔 ， 如 
图 1-35 所 示 。 


[2 NySQL Server 5.5 Setup 


六 ENySQL Server 5.5 Setup 


End-User License Agreement 


Welcome to the MySQL Server 5.5 Setup 
Wizard 


Please read the following license agreement carefully 


GNU GENERAL PUBLIC LICENSE 

Ve ion 2, June 1991 
The Setup Wizard will install MySQL Server 5.5 on your 
computer. Click Next to continue or Cancel to exit the Setup 
Wizard. 


Copyright (C) 1989, 1991 Free Software Foundation, Inc., 

51 Franklin Street, Fifth Floor, Boston, Mà 02110-1201 VSA 
Everyone is permitted to copy and distribute verbatim copies 
of this license document, but changing it is not allowed. 


Preamble 


The licenses for most software are designed to take away your 
freedom to share and change it. By contrast, the GNU General Public 
License is intended to guarantee your freedom to share and change 
free 


software--to make sure the software is free for all its users. This 
Copyright (c) 2000, 2011, Oracle and/or its affiliates. All 


rights reserved, [v]I accept the terms in the License Agreement 


图 1-34 开始 安装 图 1-35 同意 许可 安装 


(4) 单 击 [_Nex_ HH, FIIF “Choose Setup Type( 选 择 安装 类 型 )” 对 话 框 ， 要 选择 
MySQL HZR, Mihi Custom (HEX) 单 选 按钮 ， 继 续 进 行 下 一 步 的 安 厂 ， 如 
图 1-36 所 示 。 

(5) 打开 “Custom Setup《〈 目 定义 安装 )” 对 话 框 ， 在 这 个 对 话 框 页面 中 ，MySQL 提醒 
使 用 者 将 MySQL 安装 至 预 设 的 路 径 ， 这 里 将 路 径 改 为 CAMySQL, An 1-37 所 示 。 


iS NySQL Server 5.5 Setup 1 名 NySQL Server 5.5 Setup 


Choose Setup Type Custom Setup 


Choose the setup type that best suits your needs Select the way you want Features to be installed. 


Click the icons in the tree below to change the way Features will be installed. 


Typical 


Installs the most common program Features. Recommended For most users. = 3-1 ESTIS Install MySQL Server 


Client Programs 
Debug binaries 


E » | Development Components 


Allows users to choose which program features will be installed and where & z| Debug Symbols This feature requires 22MB on your 
they will be installed. Recommended for advanced users. &9 » | Server data files hard drive. It has 2 of 2 
subfeatures selected. The 


subfeatures require 62MB on your 
M ta hard drive. 
All program Features will be installed. Requires the most disk space. 
Location: CiMysgll 


图 1-36 ”选择 文件 安装 类 型 图 1-37” 设 定 目 定 义 安装 路 径 


(6) 确认 后 ， 单 击 L_Next__ HET. 47 "Ready to install MySQL Server 5.5 (准备 开始 安 
d)" oie, WE 1-38 所 示 。 
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(7) 单 击 __mstal 按钮 打开 “Installing MySQL Server 5.5 (安装 MySQL )” 对 话 
框 ， 提 示 安 装 的 进度 ， 如 图 1-39 Wr. 


s MySQL Server 5.5 Setup im MySQL Server 5.5 Setup 


Ready to install MySQL Server 5.5 Installing MySQL Server 5.5 


Click Install to begin the installation. Click Back to review or change any of your Please wait while the Setup Wizard installs MySQL Server 5.5. 


installation settings. Click Cancel to exit the wizard. 


Status: Copying new files 


图 1-38 ”准备 开始 安装 对 话 框 图 1-39 ”提示 安装 进度 
(8) 由 于 下 载 安 闫 的 是 企业 版 的 MySQL， 安 装 到 最 后 会 打开 “MySQL Enterprise 


(MySQL 企业 版 )” 对 话 框 ， 显 示 该 版 本 的 一 些 信 息 ， 如 图 1-40 所 示 。 
(9) ÁL nts 上 按钮 ， 提 示 进 一 步 的 信息 ， 如 图 1-41 所 示 。 


MySQL Enterprise | NySQL Enterprise 


` A MySQL Enterprise subscription is the most MySQL 
hensive offering of MySQL database " 。 。 
ofl do Muir The MySQL Enterprise Monitor Service 
M Lj S QL. ë business achieves the highest levels of reliability, —-— : 
security, and uptime. | * Quickly identifies your 
Enterprise An Enterprise Subscription includes: most expensive SQL code 
across all your servers. 


1. The MySQL Enterprise Server - The most reliable, secure, and up-to-date * MySQL Advisors and 125+ 
version of the world's most popular open source database. Best Practice Rules ensure 
security and performance. 


2. MySQL Enterprise Monitor Service - An automated virtual datab 


assistant. . 
* Alerts and Expert Advice 


on howto fix problems and 
tune for peak performance. 


-Onmoreinto attona 


图 1-40 MySQL 企业 版 信息 图 1-41 进一步 提示 信息 


(10) HAL nets 按钮， 打开 完成 安装 对 话 框 ， 单 击 选 择 “Launch the MySQL 
Instance Configuration Wizard (装载 运行 MySQL 确认 问 导 )” 复 选 按 钮 ， 如 图 1-42 所 示 。 

(11) 单 击 [_Fnish_j 按 钮 ， 打 开 装 载运 行 MySQL 确认 向 导 对 话 框 ， 如 图 1-43 所 示 。 
Hz, FIIF “MySQL Server Instance Configuration Wizard CZ 
模式 确认 )” 对 话 框 ， 这 里 单 击 选择 “Standard Configuration. 〈 标 准确 认 模 式 )” 单 选 按 
钮 ， 如 图 1-44 所 示 。 

(13) 选择 确认 模式 后 再 单 击 |! 让 按钮 ， 打开“ 了 Please set the Windows OPtions 
(设置 Windows 的 选项 )” 对 话 框 ， 单 击 选择 所 有 的 复 选 按钮 ， 其 中 Install As Windows 
Service 表示 将 MySQL 数据 库 服务 器 注册 为 Windows 的 服务 ， 以 方便 管理 ，Launch the 
MySQL Server automatically 表示 目 动 运行 MySQL 数据 库 ; Include Bin Directory in Windows 
PATH 是 把 MySQL 相关 的 命令 行 工具 加 入 命令 行 目 动 人 租 找 的 路 径 中 ， 以 方便 调用 MySQL 命 


f PHP+ 


令 。 设 置 后 的 对 话 框 如 图 1-45 所 示 。 


ig EySQL Server 5.5 Setup 


NySQL Server Instance Configuration Wizard 


Welcome to the MySQL Server Instance 
Completed the MySQL Server 5.5 Setup Configuration Wizard 1.0.17.0 


Wizard 
The Configuration Wizard will allow you to configure the 


MySQL Server 5,5 server instance. To Continue, click 


Click the Finish button to exit the Setup Wizard. Next. 


Launch the MySQL Instance Configuration Wizard 


图 1-42 “完成 安装 ”对 话 框 


NySQL Server Instance Configuration Wizard 


MySQL Server Instance Configuration MySQL Server Instance Configuration 


Configure the MySQL Server 5,5 server instance. Configure the MySQL Server 5,5 server instance. 


Please select a configuration type. Please set the Windows options. 


[v Install As Windows Service 


"n This is the recommended way to run the MySQL server 
O on Windows, 


Service Name: [MySQL v | 


[V Launch the MySQL Server automatically 


C Detailed Configuration 


"M Choose this configuration type to create the optimal server setup for 
this machine. 


Use Es on machines that do not already have a MySQL server 
installation. This will use a general purpose configuration For the a: 
server that can be tuned manually. Check this option to include the deum containing the 

server | client executables in the Windows PATH variable 


so they can be called from the command line. 


x Back | Cancel | 


<Back | Cancel | 
图 1-44 ”选择 确认 安装 模式 图 1-45 设置 Windows 选项 


| 按钮， 打开 “Please set the security options Ciz E zz ew" op 
i 单 击 选 择 “Modify Security Settings CMA ZR Y EO" RFA, JEU UC AN BU TET 2z 

装 时 设置 的 root 的 密码 ， 本 书 设 置 的 密码 为 admin， 后 面 章节 数据 库 登 录 全 是 使 用 
admin。 如 果 需 要 使 用 匿名 用 户 ， 可 以 单 击 选 择 “Create An Anonymous Accout" £ dz 
来 创建 ， 如 图 1-46 Br. 

(15) ffs Bi | 按钮， 打开 最 后 的 “Processing configuration 〈 进 程 确认 测 
试 )” 对 话 框 ， 单 击 “Excute〈 执 行 )” 对 话 框 进入 最 后 的 配置 确认 ， 并 显示 配置 的 结 末 ， 如 
图 1-47 所 示 。 

安装 完成 后 ， 单 击 : Hz. MySQL 数据 库 的 安装 就 完成 了 。 用 上 述 的 方法 安装 完 
数据 库 后 ， 打 开 C 盘 下 的 MySQL 文件 来 ， 里面 有 个 my.ini 的 配置 文件 ， 由 于 是 默认 安 闭 所 
以 三 找到 如 下 的 代 但 : 


#Path to the database root 
datadirz2"C:/Documents and Settings/All Users/Application Data/MySQL/MySQL Server 5.5/Data/" 


ABUS PE AGE US S AE B1. BL Jes T c en PUE TUAE SC EIS] ics Po n] EA EITE HH. 
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同时 修改 MySQL 的 默认 字符 集 为 gpbk， 即 查找 character-set-server， 然 后 将 后 面 的 字符 集 进 
行 修改 。 


NySQL Server Instance Configuration Wizard bj NySQL Server Instance Configuration Wizard 


MySQL Server Instance Configuration MySQL Server Instance Configuration 


Configure the MySQL Server 5,5 server instance. Configure the MySQL Server 5.5 server instance. 


Please set the security options. Processing configuration ... 


J Modify Security Settings 
Prepare configuration 
Mew root password: [^ Enter the root password. Sd ep : 
(vj Write configuration file (CAMysqlimy ini) 
| root | 


n D poke 
Confirm: | | Retype the password. (9j Start service 


[ Enable root access from remote machines (V Apply security settings 


Configuration file created. 
Windows service MySQL installed. 
[ Create An Anonymous Account Service started successfully. 
This option will create an anonymous account on this server. Please Security settings applied. 
note that this can lead to an insecure system. Press [Finish] to close the Wizard. 


x Back |L ne> ] Cancel | 
图 1-46 确认 安全 设置 图 1-47 最 后 的 配置 确认 


MySQL 数据 库 并 没有 图 形 化 的 管理 接口 ， 必 须 使 用 文学 接口 输入 数据 库 语法 进行 数据 

库 的 建立 与 管理 ， 这 对 于 不 熟悉 数据 库 语法 的 人 是 一 大 困扰 。 有 人 束 帮 MySQL 设计 了 Web 

页 的 管理 接口 ， 通 过 Web 浏览 髓 就 可 以 实现 MySQL 的 各 项 管理 功能 。 管 理 MySQL 的 工 

具 比 较 多 日 比较 出 名 的 有 phpadmin、EMS MySQL 等 ， 各 种 管理 工具 都 大 同 小 异 。 这 里 介绍 

一 区 窗口 化 操作 管理 的 平台 软件 EMS MySQL Manager Lite， 这 和 套 管 理 接 口 有 目 己 的 官方 网 

站 ， 只 要 在 网 址 列 输 入 http://sqlmanager.net/products/mysql/manager/ 即 可 看 到 这 套 工 具 的 说 明 
与 介绍 (如 图 1-48 所 示 )， 并 提供 免费 
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图 1-48 打开 可 以 下 载 的 页 面 


7PHP-^ 


之 所 以 在 这 里 特别 推荐 这 个 MySQL 的 管理 软件 ， 是 因为 它 是 MySQL 官方 提供 的 
ODBC 接口 程序 ， 系 统 安 朔 这 个 程序 之 后 ， 融 可 以 通过 ODBC 来 访问 MySQL， 这 样 就 可 
以 实现 SQLServer, Access 和 MySQL 之 间 的 数据 转换 ， 还 可 以 文 持 ASP 访问 MySQL žr 
5E. "X EMS MySQL Manager Lite 的 步骤 如 下 《在 光盘 中 system 文件 夹 下 也 有 下 载 的 
安装 文件 )。 

(1) 下 载 的 文件 是 安装 文件 ， 可 以 直接 安 狼 ， 如 图 1-49 Bron. 

(2) 双击 安装 文件 打开 “Laneguage Selection (语言 选择 )” 对 话 框 ， 单 击 选择 “英语 
(美国 )” 列 选项 ， 如 图 1-50 所 示 。 
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IHP amu c) umo IND Mhon 


"05 -gd mE Ciis DD | Language Selection | 
v EY 各 到 | Select a language you would like the wizard to proceed with. 


Huy pm £5 


m) Eezccqgre ns 1e p , . | 
gy winiTRH ES L Choose installation language: 


Ty Anetan 
o tox RI ayigleh 5 Dexia o0 ghgeh S D7eY.44cEn hr 德 知 (德国 ) 


一 一 EM5 Database Management Solutions, Inc. 


i Ini] x) 


BRAN: vürie7-1 | 


1-49 下 载 的 安装 文件 1-50 选择 安装 语言 


(3) 单 击 Next (下 一 步 ) 按钮 ， 打 开 欢 迎 界 面 如 图 1-51 所 示 。 
(4) 单 击 Next (下 一 步 ) 按钮 ， 打 开 同 意 注 册 对 话 框 ， 如 图 1-52 所 示 。 
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Welcome to the Installation Wizard License Agreement 

Please read the following license agreement carefully. 
Welcome to the EMS SOL Manager 2007 for MySQL Setup 
program. This program will install EMS SQL Manager 2007 for 
MySQL on your computer. 


Please closely read the following license agreement. Do you accept all the terms of the following 


. . : license agreement? 
It is strongly recommended that vou exit all windows : 


programs before running this Setup program. Click Cancel to Copyright (C) 1999-2007 EMS Database Management Solutions, Inc. 

quit Setup and close any programs you have running. Click. ll rights reserved. 

Next to continue with the Setup program. 
IMPORTANT: PLEASE READ THIS AGREEMENT CAREFULLY BEFORE USING THE 
SOFTWARE. 

WARNING: This program is protected by copyright lav and 

international treaties. END USER LICENSE AGREEMENT 
EMS Database Management Solutions, Inc. ("EMS"'] agrees to provide the user ("USER") 


Unauthorized reproduction or distribution of this program, or with a copy of this software product ("SOFTWARE"), and grants the USER a limited license to 
any portion of it, may result in severe civil and criminal use the SOFTWARE. This LICENSE AGREEMENT ("LICENSE") defines what the USER may 
penalties, and will be prosecuted to the maximum extent do with the SOFTWARE, and contains limitations on warranties, liabilities and remedies. This 
possible under law. LICENSE may be revoked by EMS at any time without notice if the USER fails to comply with ~ 


EMS Database Management Solutions, Inc. 


1-51 ZRIN Pi 1-52 同意 注册 对 话 框 


(5) 单 击 选择 “Yes，Iasgree with all the terms of this license agreement (我 同意 注册 )” 复 
选 按钮 ， 然 后 再 单 击 Next (下 一 步 ) 按钮 ， 打开“Destination Folder ZII)” XUME, 
这 里 为 了 操作 和 管理 方便 ， 选 择 默认 的 安装 ， 如 图 1-53 所 示 。 

(6) 单 击 Next (下 一 步 ) 按钮 ， 打开 “Program Group“〈 添 加 到 Windows 的 组 件 )” 对 
话 框 ， 如 图 1-54 所 示 。 
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Destination Folder 


Click Next to install the application to this folder, or click Browse to install to a 
different location. 


Select the destination folder where you want to install EMS SQL Manager 2007 for MySQL. To 
install to a different location, click Browse, and select another folder. 


Select installation folder: 


C:\Program FilesE MSSSQL Manager for MySQL 


| 


Disk space usage 


— — EMS Database Management Solutions, Inc. - 
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Program Group 


Select the program group where the Installation Wizard will install 
application shortcuts. 


Select program group: 
EMS 


Adobe 

Apache HTTP Server 2.2 
Autodesk 

Cool Edit Pro 2.1 

CorelDRAW Graphics Suite x5 
Microsoft Silverlight 


Snaglt 7 

WinRAR 

云端 软件 平台 

工行 网 银 客 户 端 软件 
方正 0CR 世 纪 版 


v 


图 1-53 ”设置 安 闭 路径 


EMS Database Management Solutions, Inc. - 


1-54 “添加 到 组 件 ” 对 话 框 


(7) "Ri Next (下 一 步 ) 按钮 ， 打 开 “Ready to Install the Program. (准备 开始 安装 )” 对 


(8) 单 击 Next《〈 下 一 步 ) 按钮 ， 则 打开 “Setup Status (ZI EE)” oue, Jem HA 


的 安装 进度 ， 如 图 1-56 所 示 。 
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Ready to Install the Program 
The Installation Wizard is ready to install the EMS SQL Manager 2007 for 
SüL. 


X» 


Es. 


You are now ready to install EMS SOL Manager 2007 for MySQL. 


Press the Next button to begin the installation or the Back button to re-enter the installation 
information. 


EMS Database Management Solutions, Inc. 
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Setup Status 


(<Back J[ We» ] [Cance! ] 
Kl1-55 “准备 安装 ”对 话 框 
(9) 安装 完成 后 ， 打 开 人 确认 安装 对 话 框 ， 单 击 选 择 上 和 面 的 两 个 复 选 按 钮 。 如 图 1-57 


Bia. 


Please wait. EMS SQL Manager 2007 for MySQL installation is in progress. 


If vou want to interrupt installation process, press the Cancel button. But in this case correct 
working of the program is not guaranteed. 


Copying file... 
C:\Program Files*E MSNSQL Manager for MySQL*MyM anager.exe 
[aaa — —À6À 8 ÁP —— O) 


EMS Database Management Solutions, Inc. 


图 1-56 ”提示 安装 进度 


(10) 单 击 Finish( 完 成) 按钮 ， 即 可 安装 。 由 于 设置 安装 完成 后 打开 EMS MySQL 软 
件 ， 所 以 第 一 次 运行 的 时 候 会 打开 试用 注册 对 话 框 ， 如 图 1-58 所 示 。 
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Installation Complete 


EMS SQL Manager 2007 for MySQL has been 
successfully installed. 


Press the Finish button to exit Setup program. 


Launch SQL Manager for MySQL now 
Add SQL Manager for MySQL shortcut to desktop 


E 
图 1-57 确认 安装 


Unregistered Copy 


Thank you for evaluating SQL KNanager 2007 for NySQL! ^ 


This is a 3O0-day trial version. To xake rure you do not 
receive this notification any more, you should purchase a 


Kepgister SQL BNanager 2007 for By5Q0L 


Please enter the regatration Information vou received when purchasing 
SÒL Manager 2007 for My SOL. 


pA * you Ww U onu 


the necessary registration information. 


'PHP- 


C | MySQL 数 据 库 的 应 用 


MySQL 数据 库 和 它 的 Web 管理 接口 EMS MySQL 的 安装 与 环境 设 定 ， 都 已 经 准备 就 绪 
了 。 接 下 来 说 明 MySQL 数据 库 的 系统 环境 ， 以 及 如 何 利用 EMS MySQL 建立 与 管理 
MySQL 数据 库 。 
1. MySQL 的 目录 
在 安装 好 MySQL 之 后 ， 会 发 现 C 磁盘 张 动 左 中 多 了 一 个 MySQL 文件 夹 。 在 此 文件 夹 
PXRH—UESHaEOUPEXG, üHÉ 1-59 Pr. 
' C: Mrsql DER 
Tr 9:80) rm) KEA IAM 帮助 0 Aw 


QAE- O- Ø PER prex D 
地 址 (p) C: Mysql 


ERAI TEX in - data - include 
C9 创 建 一 个 新 文件 来 
将 这 个 玄 件 来 发 布 到 
e Web : i - Én Wanager 3 - share 
kg 共享 此 文件 夹 
á -o E rare ini EI mu odb-heavy-. 
一 GE E 
F 5 KB | 
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本 地 磁盘 (CD) = my—medium. ini 
E E reis | EI rans TA 
g x: s m 


q 我 的 电脑 
&j 网 上 邻居 


13 个 对 象 
图 1-59 ”完成 后 的 MySQL 文件 夹 
这 些 目 录 文 件 夹 的 说 明 如 表 1-2 PTR. 


表 1-2 目录 文件 夹 的 说 明 


目录 名 称 m OX 5 Hx 
bin 存放 主要 的 程序 与 工具 程序 ， 如 mysql. mysqladmin 等 程序 
dus md vaa 以 后 建 好 的 数据 库 和 MySQL. 系统 本 身 内 建 的 数据 库 都 存放 在 这 
YE 
include 用 于 放置 MySQL 所 有 的 .h 文件 
lib 存放 驱动 .dll 文件 和 .lib 文件 
share 存放 主要 设 定 文件 与 记录 文件 


2. 用 EMS MySQL Manager 管 理 MySQL 

下 和 面 来 说 明 如 何 用 EMS MySQL Manager 实际 操作 ， 建 立 与 管理 MySQL 数据 库 。 要 建 
也 一 个 名 为 test_db 的 MySQL 数据 库 以 及 新 增 name 数据 表 ， 操 作 步 骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL", 进入 MySQL 数据 库 的 管理 接 
口 ， 如 图 1-60 所 示 。 
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Database View Tools Services Plugins Options Windows Help 

i 4 d "M Y CEIC € 3B -V- E- 3. 
P create 7 | I) | aa t | 司 Getting Started 


Databases 


m Create new database 
m Manage existing database(s) 


Database Tools 


"A Execute SOL script 


€ Manage users 


; Help and Support 


(9 SQL Manager 2007 help system 
(9 MySQL reference 


Internet Resources 


12 SQL Manager 2007 home page g- Support Center 


=| SQL Manager 2007 on-line documentation Q SQL Manager 2007 FAQ 


1-60 3A MySQL 数据 库 的 管理 接口 


(2) 选择 亲 单 栏 中 Database FHH “Create Database (创建 数据 库 )” 命 令 ， 打 开 
“Register Data base Wizard (注册 数据 表 )” 对 话 框 ， 对 话 框 的 设置 如 图 1-61 所 示 。 这 里 要 和 输 
入 表面 数 据 库 安 闭 时 的 黎 但 admin. 


Kegister Database Wizard 
Register Database 
Specify the connection parameters 
Welcome ta the Register Database wizara! 


This wizard allaovvz vou to set the connection parameters for the selected databases 
only once, giving vou the possibility ta connect them quickly afterwards. 


This wizard will quide you through the process of setting the connection parameters, 
selecting databases, and customizing their specific options. 


Host name localhost 
User name 


Pazzweord 


[] Register a single database 
[ | Use tunneling 


Tunneling 
SSH tunneling HTTP tunneling 
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(3) Hal Next〈 下 一 步 ) 按钮 ， 在 下 和 面 的 对 话 框 中 ， 选 择 默 认 的 MySQL 数据 库 ， 再 单 
市 添加 按钮 国 ， 如 图 1-62 所 示 。 


Kegister Database Wizard 
Register Database 


Select databases to register 


Available databases Selected databases 
information schema ms xul 


performance schema 


图 1-62 添加 了 预先 设置 的 默认 数据 库 


(4) 单 击 Next( 下 一 步 ) 按钮 ， 打 开 “Resister Database (注册 数据 库 )” 对 话 框 ， 设 置 
的 时 候 要 注意 把 Font charset 选择 为 GB 2312, CHARSET， 表 示 设 置 为 简体 中 文 ， 如 图 1-63 
Br. 


Register Database Wizard 
Register Database 


Set some specific options Far registered database[s] and click the Finish button 


Alas 


myzal an localhost 


Database 


Database alias myzal on localhost 


Client charset utta 


ka 
Font charset GB2312 CH&RSET bal 


Refresh objects on connection [ ]Interactive mode 

F] Login prompt before connection 

[ |Use compression protocol [] Autoconnect an startup 
Keep connection alive [| Disable transactions 
[C] Use SSL protocol 


图 1-63 设置 数据 库 属 性 
(5) 最 后 单 击 Finish (完成 ) 按钮 ， 完 成 后 的 效果 如 图 1-64 所 示 。 


^ Getting Started 


E Create new database 
8 mysal on localhost 
m Manage existing database(s) 


Database Tools 


g Execute SQL script 


€ Manage users 


; Help and Support 


(9 SQL Manager 2007 help system 


TI — mmm © MYSA reference 


Ji iai Cout ^ | Internet Resources 


的 SQL Manager 2007 home page E. Support Center 


SQL Manager 2007 on-line documentation Q SQL Manager 2007 FAQ 
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这 样 束 完成 了 数据 库 MySQL 的 狐 增 工作 ， 接 下 来 就 建立 网 页 数据 所 需 的 数据 表 。 狐 增 
的 操作 步骤 如 下 。 

(1) 建立 数据 库 MySQL 后 ， 要 把 这 个 数据 库 连 接 上 ， 单 击 工具 栏 上 的 “Connect to 
Database (连接 )” 按 钮 总 ， 将 其 连接 ， 如 图 1-65 所 示 。 


i SQL Nanager 2007 for MySQL 

Database View Tools Services Plugins Options Windows Help 

: | : :| "Mr rer 
(d create ~ | A [4 | [93 | a Z Getting Started 
Databases 


日 9 localhost 


m mysal on localhost 


Connectto Database (Shift*Ctrl«C)) create new database 

m Manage existing database(s) 
Database Tools 

g Execute SQL script 


€; Manage users 


; Help and Support 


(9 SQL Manager 2007 help system 


Hmysql on localhost E 


dau Count ^. Internet Resources 


(9 MySQL reference 


的 SQL Manager 2007 home page E. Support Center 


SQL Manager 2007 on-line documentation Q SQL Manager 2007 FAQ 


1-65 连接 数据 库 
(2) 连接 上 以 后 ， 将 选择 Table 进行 狐 增 数据 表 ， 如 图 1-66 所 示 。 


PHP+ 


t SQL Nanager 2007 for NySQL — mysql on localhost [mysqll 
jatabas Services Plugins 


i ER Create ~ | |2 (wv 


— Object E e ^ |Properties | Fields |Indices | Triggers | Data | Dependencies | DDL | 


E 9 "yum €— epum Field Name Field Ty... Size Pre... Not... Defaut ^ Comment 
mysql on localho | E mysal on localhost [my v | Host CHAR 60 0 


(il Tables 2o 3 Db CHAR 
B 


columns. priv 
User CHAR 


-E coor TA) 
Select priv (ENUM 


国 event | 
EJ func [a] Refresh Insert priv (ENUM 
Lpdate priv (ENUM 


Eze] general log H | 学 Compile 
&Ej help category E a Grants on table Delete priv ENUM 
EJ help keyword E Z Print Create priv ENUM 
& help. relation : Ql Drop priv — ENUM 
E help topic 人 Grant priv — ENUM 
-EB host : E. 必 Table Editor options rare pn 
k References p ENUM 
Restore default size - 
Index priv ENUM 
Alter priv ENLIM 


Create tmp ts ENUM 
Lock tables r|ENUM 
Create. view. ENUM 
Show. view. ENUM 
Create routinc ENUM 
Alter routine | ENUM 
Execute priv [ENUM 
Event priv ENLIM 
Trigger. priv (ENUM 


: ocalhostimysql on localhost!Tables:columns z 

: Field Type | 

iS Host CHAR(EO) | c Truncate table 
iE Db CHAR(64) 
HE User CHAR(18) 
iE Table name CHAR(B4) 
HE Column name CHAR(B4) 
图 Timestamp TIMESTAMP 
£8] Column. priv sETCSELECTvINSERTvUr| M Es Drop selected field(s) 


oleilejeileioleileioileieioieie 


| 去 | 三 | 三 | 三 | 三 | 三 | 三 | 三 | 三 | 三 | 三 | 三 | 三 | 三 | 三 | 


十 


Olooo0o0o0o0o0o0o0o0o0o0o0ooooooso 


E. Add new field 
El Edit selected field 


EE B R8 (E) DE D RE E DE DE RE DE DE DE RE D DE DE RED DD DB DE 


国 国 国 国 国 国 国 国 国 国 国 国 国 国 国 国 固 固 固 固 固 回 


olooo0o0 
| 
zm mmm 
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G) 数据 库 右 方 画 面 会 出 现 新 建 数 据 表 (Table) 的 设 定 区 域 ， 单 击 “Create New Table (6/J 
建新 表格 )” 选 项 ， 单 击 后 即 可 建立 一 个 数据 表 ， 含 有 “Table”“Fields”“DDL”3 个 选项 
卡 ， 先 在 “Table” 中 输入 数据 表 名 “name” 如 图 1-67 Pr. 


: New Table — [mysql on localhost] 


Table Properties 
E mysql on localhost [mysql] v 


Table name 


con E c Storage Options 


if Compile Storage engine 


Q9) Show SQL help Row format 
| [EP] Restore default size Min. rows 


ji 


Max. rows 


Auto increment value 


Average row lenath 


Size for index key blocks 


[C] Check sum [C] Delay key write 
[ ]Pack keys [C] Temporary 


Character Sets |File Options | Merge Table Options | Federated Table Options 


Character set Default v 


Collation |Defaut v | 


Description 
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(4) 在 “Fields” 选 项 卡 中 ， 输 入 数据 域名 以 及 设 定 数据 域 位 的 相关 数据 ， 如 图 1-68 
所 示 。 
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s New Table — [mysql on localhost] 


TIE 
g mysal on localhost [mysql] v 
coor E 
4f Compile 
Q9) Show SQL help 


Table Fields 


Fields | DDL 


Primary Key Column Name 


Data Type Size 
INTEGER 10 
VARCHAR 


[E] Restore default size 


1-68 WU E “Fields” 


(5) 如 果 要 设 定 字段 的 属性 ， 例 如 学 生 编写 Id 要 设 定 目 动 编写 的 属性 ， 那 么 只 要 利用 也 


标 双 击 字 段 名 称 ， 丈 会 弹出 字段 的 编辑 方块 ， 在 这 里 可 以 义 选 “Not null PAE)” 


“Autoincrement〈 目 动 编号 )”“Primary key〔 关 键 字 )” 的 复 选 按钮 选项 


Br. 


Edit field 'ID' 


Field name ID 


Type INTEGER v 


Use dimension 
Field dimension 


Size 10 | Precision 


Field flags 
Not null 
[C] Unsigned 


[ ]Zerofill 


[C] Unique 
Primary key 


values 


Default | Field charset | Description 


页 ， 设 置 如 图 1-69a, b 


Edit field 'name' 


Field name name| 


Type VARCHAR v 


Use dimension 
Field dimension 


Size 20 


Field flags 
Not null 
Unsigned 


Zeroafill 


[ ]unique 
Autoincrement 
Primary key 


Values 


8 


Default | Field charset | Description 


图 1-69 字段 属性 的 设 定 


ies 解决 PHP 与 MySQL 乱 码 问题 


在 初次 配置 PHP 运行 文 持 MySQL 后 ， 对 于 初学 者 来 说 ， 通 上 中 文 乱 但 是 开始 学 习 时 过 


1 PHP*MySQL*Dreamweaver ssi nsa 


到 的 第 一 个 问题 ， 本 节 将 重点 介绍 如 何 解决 这 个 问题 。 

般 说 来 ， 乱 人 码 的 出 现 有 两 种 原因 。 首 先是 由 于 编码 (Charset) 设置 错误 ， 导 致 浏览 句 
以 错误 的 编码 来 解析 ， 从 而 出 现 了 满 屏 乱 七 八 糟 的 符号 ， 不 能 正常 显示 中 文 ， 其 次 是 文件 被 
以 错误 的 编码 打开 ， 然 后 保存 ， 比 如 一 个 文本 文件 原先 是 GB2312 编码 的 ， 却 以 UTF-8 编码 
打开 再 保存 。 

要 解决 上 述 乱 码 问 题 ， 首 先 需 要 知道 开发 中 哪些 环节 涉及 了 编码 。 

(OD 文件 编码 被 修改 。 指 的 是 页 面 文件 Chtmb .php 等 ) 本 身 是 以 何 种 编码 来 保存 的 。 
记事 本 和 Dreamweaver 在 打开 页 面 的 时 候 会 目 动 识别 文件 编码 ， 因 而 不 太 会 出 问题 。 而 
ZendStudio 却 不 会 目 动 识别 编码 ， 它 只 会 根据 首选 项 的 配置 ， 固 定 以 某 种 编码 打开 文件 ， 如 
果 一 旦 用 错误 编码 打开 文件 ， 当 做 了 修改 之 后 保存 时 ， 乱 码 就 出 现 了 。 

(2) 页 面 声明 编码 不 统一 。 在 HTML 代码 HEAD 里 面 ， 可 以 用 <meta http-equiv= 
"Content-Type" content-" text/html; charset=" XXX" /> 来 告诉 浏览 器 网 页 采用 了 什么 编 公 。 目 前 
中 文 网 站 开发 中 XXX 主要 用 的 是 GB2312 和 UTF-8 两 种 编码 。 

(3) 数据 库 连接 编码 不 正确 。 指 的 是 进行 数据 库 操作 的 时 候 ， 以 哪 种 编码 与 数据 库 传 输 
数据 ， 这 里 需要 注意 的 是 不 要 与 数据 库 本 喘 的 编码 混 消 ， 比 如 MySQL 内 部 默认 是 latinl 编 
ti, EEL MySQL 是 以 latinl 编码 来 存储 数据 ， 以 其 他 编码 传输 给 MySQL 的 数据 会 被 
转换 成 latinl 编码 。 

知道 了 网 站 开发 中 哪些 地 方 涉及 到 了 编码 ， 也 就 知道 了 产生 乱码 的 原因 。 下 面 是 一 些 常 
见 的 错误 情况 与 解决 方法 。 

问题 一 : 数据 库 采 用 UTFS 编码 ， 而 页 面 声明 编码 是 GB2312. 

这 是 最 常见 的 产生 乱码 的 原因 。 这 时 候 在 PHP 脚本 里 面 直 接 SELECT 数据 出 来 的 就 是 
乱码 ， 需 要 在 查询 前 先 使 用 mysql_query("SET NAMES GBK") 来 设置 MySQL 连接 编码 ， 保 
证 页 面 声明 编码 与 这 里 设 定 的 连接 编 公 一 人 改 (GBK 是 GB2312 的 扩展 )。 

如 果 页 面 是 UTF-8 编码 的 话 ， 可 以 用 mysql query"SET NAMES UTF8")， 注 意 是 
UTFS 而 不 是 一 般 用 的 UTF-8。 假 如 页 面 声 明 的 编码 与 数据 库 内 部 编码 一 怪 则 可 以 不 设 定 
连接 编码 。 

例如 ， 本 书 的 购物 车 系统 的 数据 库 连 接 时 设置 的 编码 规则 如 下 。 


<?php 
$conn=mysql_connect("localhost","root","admin") or die(" 数 据 库 服 务 器 连接 错误 ".mysql_ 


error()); 


2 NY 


mysql query("set character set gb2312"); 
mysql query("set names gb2312"); 
2» 


MySQL 的 数据 输入 /输出 比 上 面 讲 的 更 复杂 一 些 ，MySQL 配置 文件 myini 中 定义 了 两 
个 默认 编码 ， 分 别 用 [client] 里 的 default-character-set 和 [mysqld] 里 的 default-character-set 来 设 
定 默 认 时 候 客 户 问 连接 和 数据 库 内 部 所 采用 的 编码 。 上 和 面 指定 的 编码 其 实 是 MySQL %7 iim 
连接 服务 器 时 候 的 命令 行 参 数 character_set_client， 来 告诉 MySQL 服务 器 接收 到 的 客户 病 数 
据 是 什么 编码 的 ， 而 不 是 采用 默认 编码 。 
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问题 二 : 页 面 声明 编 但 与 文件 本 续 纲 码 不 一 致 。 

这 种 情况 很 少 发 生 ， 因 为 如 采编 码 不 一 致 ， 美 工 做 页 面 的 时 候 在 浏览 器 看 到 的 残 是 乱 
人 码 。 蝎 多 时 候 是 发 布 以 后 修改 一 些小 BUG， 由 于 以 错误 编码 打开 页 面 然后 保存 导致 的 乱 
5j: 或 者 是 用 菜 些 FTP 软件 直接 在 线 修改 文件 ， 比 如 CuteFTP， 由 于 软件 编码 配置 错误 而 叶 
伊 转 换 错 了 编码 。 

问题 和 三， 服务 右 Apache 设 趾 了 服务 器 全 局 的 默认 编码 。 

一 些 租 用 虚拟 主机 的 朋友 ， 明 明 上 述 3 项 编码 都 设置 正确 ， 但 还 是 有 乱码 。 比 如 ， 网 页 
是 GB2312 编码 的 ， 正 等 浏览 器 打开 却 总 是 识别 成 UTF-8， 网 页 HEAD 里 面 已 经 声明 是 
GB2312 了 ， 手 动 修改 浏览 器 编码 为 GB2312 后 页 面 显示 正常 。 产 生 原 因 是 服务 器 Apache 设 
定 了 服务 器 全 局 的 默认 编码 ， 在 httpd.conf 里 而 加 了 AddDefaultCharset UTF-8。 这 时 候 服务 
ERHI HTTP 给 浏览 器 ， 其 优先 级 比 页 面 里 声明 编码 高 ， 目 然 浏 览 器 就 发 生 识别 错 
误 。 解 决 办 法 有 两 个 ， 管 理 员 在 配置 文件 目 己 的 虚 机 里 加 上 一 条 AddDefaultCharset GB2312 
来 复 辣 全 局 配置 ， 或 者 在 目 己 目录 的 .htaccess 里 配置 。 
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PHP 是 一 种 易于 使 用 的 服务 器 端 脚本 语言 ， 只 需要 很 少 的 编程 知识 就 能 使 用 PHP. 建立 一 个 真 
正 具有 交互 功能 的 Web 站 点 。 对 于 初学 者 而 言 ， 是 需要 花 一 些 功 夫 去 掌握 PHP 的 编程 基础 。 本 书 
以 最 简单 易学 的 方法 介绍 一 些 PHP 的 基本 语法 ， 包 括 变 量 、 常 量 、 运 算 符 、 控 制 语句 以 及 数组 
等 ， 通 过 学 习 这 些 基础 知识 使 谈 者 能 更 深入 地 了 解 PHP。 


MATIE E 


要 掌握 以 下 知识 点 : 


y 在 Dreamweaver 进行 PHP 开发 平台 的 搭建 


© PHP 程序 编写 的 基础 知识 

(—7 掌握 PHP 表单 变量 的 使 用 

© PHP 程序 中 常量、 变量 、 表 达 式 以 及 遂 数 的 基础 
O 重点 掌握 PHP 和 MySQL 数据库 的 操作 


€2u QUIT 


在 Dreamweaver 中 建立 PHP 执 行 环境 
Dreamweaver CS 5.5 这 套 软 件 提供 了 网 站 开发 的 整合 性 环境 ， 它 可 以 文 持 不 同 服务 器 技 | 
术 ， 如 ASP, PHP. JSP 等 ， 建 立 动态 文 持 数据 库 的 网 络 应 用 程序 ， 同 时 也 能 让 不 情 程 序 代 
码 的 网 站 设计 人 员 或 初学 者 ， 能 在 不 用 捅 写 程 序 代 码 的 情况 下 ， 学 习 动 态 网 页 技术 的 设计 。 
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在 开始 制作 网 站 之 前 ， 还 要 了 解 在 Dreamweaver CS 5.5 中 的 网 页 设计 和 发 布 流程 。 它 可 
以 分 为 如 下 5 个 主要 步骤 。 

第 一 步 : 规划 网 站 站 点 

需要 了 解 网 站 建设 的 目的 ， 确 定 网 站 提供 的 服务 以 及 针对 的 是 什么 样 的 访问 者 ， 以 确定 
网 页 中 应 该 出 现 什 么 内 容 。 

第 二 步 : 建立 站 点 的 基本 结构 

Dreamweaver CS 5.5 可 以 在 本 地 计算 机 上 建立 出 整个 站 点 的 框架 ， 并 在 各 个 文件 夹 中 合 
理 地 安置 文档 。Dreamweaver CS 5.5 可 以 在 站 点 窗口 中 以 两 种 方式 显示 站 点 结构 ， 一 种 是 目 
录 结 构 ， 田 一 种 是 站 点 地 图 。 可 以 使 用 站 点 地 图 方式 快速 构建 和 查看 站 点 原型 。 一 旦 创建 了 
本 地 站 点 并 生成 了 相应 的 站 点 结构 ， 创 建 了 即将 进一步 编辑 的 各 种 文档 ， 束 可 以 在 其 中 组 织 
文档 和 数据 。 

第 三 步 : 实现 所 有 页 面 的 设计 

建立 站 点 之 后 ， 进 入 Dreamweaver CS 5.5 软件 中 ， 开 始 进 行 页 面 的 版 面 规 划 设 计 ， 利 用 
强大 的 编辑 设计 功能 实现 各 种 复杂 的 表格 ， 然 后 再 组 织 页 面 内 容 。 为 了 你 持 页 面 的 统一 风格 
可 以 利用 模板 来 快速 生成 文档 。 

第 四 步 ， 充实 网 页 内 容 

在 创建 了 基本 版 面 页 面 后 ， 束 要 往 框 染 里 填充 内 容 。 在 文档 窗口 中 合适 的 地 方 ， 可 以 输 
入 文字 和 其 他 资源 ， 例 如 图 像 、 水 平 线 、Flash 插件 和 其 他 对 象 等 ， 大 多 可 以 通过 插入 面 版 
或 插入 沫 单 来 完成 插入 。 

第 五 步 : 发 布 和 维护 更 新 

在 站 点 编辑 完成 后 ， 需 要 将 本 地 的 站 点 同位 于 Internet 服务 器 上 的 远 问 站 点 关联 起 来 ， 
把 本 地 设计 好 的 网 站 内 容 传 到 服务 器 上 ， 并 注意 后 期 的 及 时 更 新 和 维护 。 


本 地 站 点 网 站 文件 夹 规划 


在 制作 网 站 之 前 ， 首 先是 把 设计 好 的 网 站 内 容 放 置 在 本 地 设计 计算 机 的 便 盘 上 ， 为 了 方 
便 站 点 的 设计 及 上 传 ， 设 计 好 的 网 页 都 应 存储 在 Apache 服务 需 的 安 猜 路 径 下 《如 本 书 的 路 
径 为 C:\Apache\htdocs 目录 下 )， 再 用 合理 的 文件 夹 来 管理 文档 。 在 本 地 站 点 规划 的 时 候 ， 应 
该 注意 如 下 的 操作 规则 。 
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1. 设计 合理 的 文件 夹 

在 本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 夹 ， 
然后 在 其 中 再 创建 多 个 子 文件 严 ， 最 后 将 文档 分 类 存储 到 相应 的 文件 夹 下 。 

例如 ， 可 以 在 images 的 文件 夹 中 放置 网 站 页 面 的 图 片 ， 可 以 在 aboutus 文件 夹 中 放置 用 
于 介绍 公司 的 网 页 ， 可 以 在 service 文件 夹 中 放置 天 于 公司 产品 方面 的 网 页 。 如 图 2-1 所 示 
是 一 个 大 型 电子 商务 网 站 规划 建立 的 文件 夹 文档 。 


QAE- O- Pus Drix [Dg 
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图 2-1 网 站 在 本 地 硬盘 上 的 文件 夹 建立 


2. 设计 合理 的 文件 名 称 

网 站 建设 由 于 要 生成 的 文件 很 多 ， 所 以 经 常 要 用 合理 的 文件 名 称 。 这 样 操 作 的 目的 其 一 
是 为 了 方便 在 网 站 的 规模 变 得 很 大 时 ， 可 以 进行 修改 更 狐 ;， 其 二 也 是 为 了 方便 浏览 者 在 看 了 
网 页 的 文件 名 ， 束 能 够 知道 网 页 所 要 表述 的 内 容 。 

在 设计 合理 的 文件 名 时 要 注意 以 下 几 点 。 

(OD 尽量 使 用 短文 件 来 命名 。 

(2) 应 该 避免 使 用 中 文 文件 名 ， 因 为 很 多 Internet 服务 器 使 用 的 是 英文 操作 系统 ， 不 能 
对 中 文 文件 名 提供 很 好 的 文 持 ， 而 且 浏览 网 站 的 用 户 也 可 能 使 用 英文 操作 系统 ， 中 文 文件 名 
同样 可 能 导致 浏览 错误 或 访问 失败 。 

(3) 建议 在 构建 的 站 点 中 ， 全 部 使 用 小 写 的 文件 名 称 。 很 多 Internet 服务 占 采 用 UNIX 
操作 系统 ， 它 是 区 分 文件 的 大 小 写 的 。 

特别 注意 : 

在 PHP 建立 的 站 点 文件 夹 及 文件 名 一 定 要 使 用 英文 名 称 或 者 数字 名 称 ， 不 要 使 用 中 文 
名 称 来 命名 ， 否 则 会 导致 Apache 服务 器 不 能 正常 支持 该 站 点 。 


3. 设计 本 地 和 远程 站 点 为 相同 的 文件 结构 
设计 本 地 和 远程 站 点 为 相同 的 文件 结构 是 指 在 本 地 站 点 中 规划 设计 的 网 站 文件 结构 要 同 
上 传 到 Internet 服务 器 中 被 人 浏览 的 网 站 文件 结构 相同 。 这 样 在 本 地 站 点 上 的 文件 夹 和 文件 上 
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的 操作 ， 都 可 以 同 远 程 站 点 上 的 文件 夹 和 文件 一 一 对 应 。Dreamweaver CS 5.5 将 整个 站 点 上 传 
到 Internet 服务 占 上 ， 部 可 以 保证 远程 站 点 是 本 地 站 点 的 完整 的 拷贝 ， 方 便 浏览 和 修改 。 


建立 流畅 的 浏览 顺序 DMA 


在 网 站 创建 的 时 候 首 先 要 考虑 到 网 站 所 有 页 面 的 浏览 顺序 ， 注 意 主 次 页 面 之 间 的 链接 是 
否 流畅 。 如 果 采 用 标准 统一 的 网 页 组 织 形式 ， 可 以 让 用 户 轻 松 上 自如 地 访问 每 个 想 要 访问 的 网 
页 。 这 样 能 提高 浏览 的 兴趣 ， 加 大 网 站 的 访问 量 。 建 立 站 点 的 浏览 顺序 ， 要 注意 如 下 几 个 方 
— 

一 : 每 个 页 面 建 立 首 页 的 链接 

diio —— 
束 可 以 保证 用 户 在 不 知道 自己 目前 位 置 的 情况 下 ， 快 速 返回 到 首页 中 ， 重 狐 开 始 浏 览 站 点 中 
其 他 内 容 。 

第 二 : 建立 网 站 导航 

应 该 在 网 站 任何 一 个 页 面 上 建立 网 站 导航 ， 通 ; 过 导航 提供 站 点 的 简明 目录 结构 ， 引 叶 用 
户 从 一 个 页 面 快速 进入 到 其 他 的 页 面 上 。 

第 三 : 突出 当前 页 位 置 

在 网 站 页 面 很 多 的 情况 下 ， 往 往 需要 加 入 当前 页 在 网 站 中 的 位 置 说 明 ， 或 者 是 加 入 说 明 
的 主题 ， 以 帮助 浏览 者 了 解 目 前 所 处 的 访问 位 置 。 如 果 页 面 髓 套 过 多 ， 则 可 以 通过 创建 “前 
进 ” 和 “后 退 ” 之 类 的 链接 ， 来 帮助 浏览 者 进行 浏览 。 

第 四 : i ei 

对 于 一 些 禹 数据 库 的 网 站 ， 还 应 该 给 浏览 者 提供 搜索 的 功能 ， 或 是 给 浏览 者 提供 索引 检 
ME MUR E 

第 五 : 必要 的 信息 反馈 功能 

网 站 建设 发 布 后 ， 都 会 存在 一 些小 问题 ， 从 浏览 者 那里 及 时 获取 对 网 点 的 意见 和 建议 是 
非常 重要 的 。 为 了 及 时 从 用 户 处 了 解 到 相关 信息 ， 应 该 在 网 页 上 提供 用 户 同 网 页 创作 者 或 网 
站 管理 员 的 联系 途径 。 常 用 的 方法 是 建立 留言 板 或 是 创建 一 个 E-mail 超级 链接 ， 帮 助 用 户 快 
速 将 信息 反馈 到 网 站 中 。 


_ 定 义 本 章 PHP 网 页 测试 网 站 


Dreamweaver 要 开发 网 站 之 朋 ， 一 定 要 先 定 义 网 站 ， 利 用 Dreamweaver CS 5.5 *x& ri" 
一 “管理 站 点 ”命令 来 进行 管理 。 使 用 Dreamweaver CS 5.5 进行 网 页 布局 设计 时 ， 首 先 需 要 
FH E Sons ea n] SEXE NC Es o 

定义 本 章 所 要 学 习 的 PHP. 语法 网 页 的 站 点 具体 操作 步骤 如 下 。 

(1) 首先 在 CAMApacheMtdocs 路 径 下 建立 php 文件 夹 ， 如 图 2-2 所 示 ， 本 章 所 有 建立 的 
PHP 程序 文件 都 将 放 在 该 文件 夹 下 。 

(2) 打开 Dreamweaver CS 5$.5， 选 择 来 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 2-3 Br. 
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C:\Apache\htdocs 
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地 址 Q) [4 C: SÁpachehhtdocs x] 转 到 


文件 和 文件 卖 任务 Q) S EIAS o p siii 
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Q 将 这 个 文件 来 发 到 


Eg 共享 此 文件 夹 


A 以 电子 邮件 形式 发 送 该 
辫 件 夹 内 的 文件 


K 删除 这 个 交 件 夹 


2-2 建立 站 点 文件 夹 php 
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2-3 “管理 站 点 ”对 话 框 


(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右边 的 “新 
建 ” 按 钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ” php. 

“本 地 站 点 文件 来” ”C:\Apache\htdocs\php\。 

如 图 2-4 Bras. 


MaRa php 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweaver 
站 点 通常 包含 两 个 部 分 ; 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 发 布 和 到 web 上 的 服务 器 上 的 远程 文件 夹 。 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 来 和 名 称 。 
站 点 名 称 : 
本 地 站 点 识 件 夹 ; | Capachehtdocs\php' 5 


2-4 建立 php 站 点 


(4) 单 击 列 表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 上 |， 打开 “基本 ” 


选项 卡 ， 进 行 如 图 2-5 所 示 的 参数 设置 。 
“RIAA”: phpe 
“连接 方法 ” 本地/ 网络 。 
“服务 右 文 件 夹 ”CC:\Apache\htdocs\。 
“Web URL”: http://127.0.0.1/。 
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Web URL: | http:j/127.0.0.1/ 


2-5 设置 “基本 ”选项 卡 


(50 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 步 
信息 ” 复 选 按钮 ， 在 “服务 需 模 型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 


7PHP-^ 


的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 2-6 所 示 。 


靖 点 设置 对 象 php 
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取出 名 称 ; 
电子 邮件 地 址 : 
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2-6 设置 “高 级 ”选项 卡 


(6) 单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 勾 选 “测试 ” 复 选 按钮 ， 
如 图 2-7 所 示 。 


站 点 设置 对 象 php 


BE 您 将 在 此 位 置 选择 学 载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
版 本 控制 Internet 服务 提供 商 (ISP) 或 web 管理 员 。 


* ”高 级 设置 


注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步骤 。 如 果 要 连接 到 Web 并 发 
布 页 面 ， 您 只 需 定 多 一 个 远程 服务 器 即 可 。 


地 址 | 连接 | 远程 | 测试 | 
Cjapacheljhtdocs 本 地 |/ 网络 [V M 


2-7 设置 “服务 器 ”参数 
单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 


才 所 设置 的 站 点 了 。 由 于 是 在 本 机 测试 PHP 网 页 ， 因 此 不 需要 设 定 “远程 信息 ”。 设 定好 
“本 地 信息 ”与 “测试 服务 器 ”之 后 ， 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 杠 ， 这 样 
束 完 成 了 Dreamweaver CS 5.5 测试 PHP 网 页 的 网 站 环境 设置 。 


PHP 程 序 编写 基础 


如 果 读 者 对 ASP 或 者 JSP 有 所 了 解 ， 应 该 知道 在 编写 这 些 网 页 程序 时 ， 可 以 将 HTML 
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cos PHPAREA 


标记 与 这 些 动态 语言 代码 混合 到 一 个 文件 中 。 然 后 使 用 特殊 的 标识 (符号 “<%%>”) 将 两 
者 区 别 开 来 。PHP 也 是 如 此 ， 可 以 与 HTML 标记 共存 ，PHP 提供 了 多 种 方式 来 与 HTML 标 
记 区 别 ， 用 户 可 以 根据 自己 的 喜好 选择 一 种 ， 也 可 以 同时 使 用 几 种 。 本 小 节 将 介绍 PHP 的 
基础 程序 结构 ， 包 括 输出 和 注释 的 方法 。 


zu PHP 程 友 结 构 


PHP 语句 与 Perl 和 C 一样， 结构 比较 严谨 ， 需 要 在 每 条 语句 后 使 用 分 号 “;” 来 作为 结 
束 ， 而 且 对 语句 中 的 大 小 写 敏感 。 

第 用 的 方式 有 如 下 3 种 。 

方法 1: PHP 标准 结构 (推荐 ) 


<?php 
Echo "hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程序 !": 
T» 


方法 2: PHP 的 简短 风格 (需要 设置 php.ini) 
<?Echo "hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程序 1";?> 
方法 3: PHP 的 SCRIPT 风格 (元 长 的 结构 》 
<script language="php">echo"hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程序 !"; </script> 


3 种 方法 输出 的 结果 是 一 样 的 ， 在 Dreamweaver 里 编辑 后 输出 的 结果 如 图 2-8 所 示 。 
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PHP 标 准 结 攀 推荐 ) 

<?php 

echo “hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程 序 !: 
T> 


PHP 的 简短 风格 需要 设置 php. ini) 
<? echo “hello, 你 好 ， 这 是 我 的 第 一 个 FHP 程序 1":; ?> 


PHPH SCRIPTAE (TERE) 
<script language-"php'5 echo“hel1lo, 你 好 ， 这 是 我 的 第 一 个 PHP 程 序 !”; </script> 


hello ,你 好 ， 这 是 我 的 第 一 个 PHP 程 序 ! 


DEZ 


图 2-8 输出 结 


实际 开发 时 ， 第 1 种 和 第 2 种 是 最 常用 的 方法 ， 即 使 用 小 于 号 加 上 问号 之 后 跟 PHP 代 
码 ， 在 程序 代码 的 最 后 ， 使 用 问号 及 大 于 写作 为 结束 ， 而 第 3 种 方法 有 点 类 似 于 JavaScript 


"P zr 


的 编写 方式 。 
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E PHP 输 册 结 果  ， 


PHP 输出 所 有 参数 可 以 用 echo0 命 令 ，echo0 不 是 一 个 函数 〈 它 是 一 个 语言 结构 )， 因 此 
不 一 定 要 使 用 小 括号 来 指明 参数 ， 单 引号 、 双 引号 都 可 以 。echo0 不 像 其 他 语言 结构 表现 得 
不 像 一 个 函数 ， 所 以 不 能 总 是 使 用 一 个 函数 的 上 下 文 。 另 外 ， 如 果 想 给 echo0 传 递 多 个 参 
数 ， 那 么 就 不 能 使 用 小 括号 。 

提示 : 

也 可 以 使 用 printO0 命 令 来 实现 ， 但 echo) 2 F6 printO 函 数 快 一 点 。 

举例 用 PHP 输出 语句 ， 包 括 HTML 格式 化 标签 ， 如 图 2-9 所 示 。 


Zi PHP 语 句 萄 出 — Microsoft Internet Explorer 加 回国 
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PHP 基 础 语法 实例 返回 


PHP 代 码 + 往 释 


<?php 
echo “<p RA RH A3 SEXE E$8o Xp"; 


(AD Internet 


2-9 4E echo 输出 字符 


Lus. PHP 程序 注释 


PHP 中 可 以 使 用 以 多 种 风格 的 注释 方式 。 
/ 第 1 种 PHP 注释 适合 用 于 多 行 */ 
// 第 2 种 PHP 注释 适合 用 于 单行 
# 第 3 种 PHP 注释 适合 用 于 单行 


PHP 注释 和 C、C++ 和 Shell 的 注释 风格 一 样 ， 以 认为 开始 ，*/ 为 结束 ， 例 如 : 


<?php 

/* 

注释 : 关于 本 段 程序 的 说 明 

该 段 程 序 主 要 用 于 建立 数据 库 的 连接 .…. 
ii 


425 pHP 编 程 基础 


?> 

单行 注释 (有 /和 # 这 两 种 ): 
<?php 
echo "说 明 "; /得 出 说 明 二 字 
echo "说 明 ";# 输 出 说 明 二 学 


?> 


注意 一 下 ， 注 释 符 号 只 有 在 <?php ?> 里 才 会 起 到 应 有 的 效果 。 


Section 


空 制 动态 输出 字符 


在 实际 的 网 页 设计 过 程 中 ， 单 使 用 echo0 函 数 命令 并 不 能 满足 实际 的 应 用 ， 如 需要 和 输出 
随机 的 数字 ， 控 制 字符 串 的 大 小 号 以 及 一 坚 特 殊 的 字符 处 理 等 音 用 操作 ， 都 可 以 通过 调用 相 
应 的 函数 命令 加 以 实现 。 


esu PHPERZARBS S Fj 


如 果 要 实现 相应 的 字符 控制 就 需要 调用 相应 的 函数 命令 ， 在 PHP 编程 中 调用 相应 的 也 
数 还 是 比较 简单 的 ， 如 使 用 rand0 函 数 来 产生 一 个 随机 数字 《范围 是 0 一 100 )。 
<?php 


echo rand(0,100); 
?> 


刷新 便 可 看 到 输出 结果 的 变化 ，rand 函数 中 的 0 和 100 为 指定 给 rand 函数 的 参数 ， 


前 面 的 0 就 意味 着 最 小 可 能 出 现 的 数值 为 零 ，100 则 意味 着 最 大 可 能 出 现 的 数值 为 100, 
如 图 2-10 所 示 。 很 多 函数 部 有 必 选 或 是 可 选 的 参数 。 


2 JPRS 一 Nicrosoft Internet Explorer 

Pic) AB) do umo) IB) Woo 

Qae- O- ado PS «mx 6 5-.[3«c 

IRIE D) AE] http: //121.0 0. 1/php/PHP/PHP Function php -HAIRAN VEPS ER Qsec p 


PHP 基 础 语法 实例 返回 


PHPICGIS ERE 


Arnd dj tok 4 — 1 PRHLIESE (范围 是 0 到 100); 
?php 
echo rand(0, 100) 


— TT rand t d: 030 10055 TRE £i randifi 68 46, 前 画 的 0 就 意味 着 最 小 可 
郁 出 现 的 数值 为 党， 100 则 意味 看 业 大 可 能 出 现 的 数值 为 100， 很 多 函 钠 都 有 必 选 或 是 可 选 的 湖 雏 。 


图 2-10 输出 随机 函数 的 结果 


"s zm 


232 截 去 字符 串 首尾 : 


使 用 trim 函数 可 以 返回 去 除 字 符 串 string 首尾 的 空白 字符 后 的 字符 串 。 
语法 : string trim(string str); 
返回 值 : 字符 串 
函数 种 类 : 资料 处 理 
在 使 用 来 目 HTML 表单 信息 之 前 ， 一 般 都 会 对 这 些 数据 做 一 些 整理 。 
<?php 
/请 理 字 符 串 中 开始 和 结束 位 置 的 多 余 空 格 
$name =" 12356789 "; 
$name = trim($name); 


echo $name; 
?> 


运行 的 结 末 可 以 将 前 后 的 空 日 去 除 。 


于 于 格式 化 输出 字符 | 


nl2brO 函 数 可 以 将 换行 字符 转换 成 HIML 换行 的 <br> 指 令 。 
语法 : string nl2br(string string); 
返回 值 : 字符 串 
函数 种 类 ， 资料 处 理 
举例 如 下 : 
<?php 
$str = "今天 的 天 气 特 别 好 ， 心 情 也 不 错 
， 决 定 去 学 校 足 球场 ， 好 好 的 足 一 场 球 。"; 
echo $str; 
echo "<br />": 
echo nDbr(Sstr); 
7» 


输出 的 结果 如 图 2-11 所 示 。 


ZU 打印 格式 化 输出 j 


PHP FF printfO 结 构 在 实现 echo 功能 的 同时 能 返回 值 (True EX False， 是 合成 功 )， 使 


用 printtO 可 以 实现 更 复杂 的 格式 。 


语法 : int printf(string format, mixed [args]...); 
返回 值 : 整数 
函数 种 类 : 资料 处 理 

<?php 

$num = 12.8; 
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(PHP 编程 基础 l 


汉 格式 化 萄 出 = Nicrosoft Internet Explorer TAR) 
HFT 编辑 区 ) 查看 WW) 收藏) IAM $B500 | Ay 


ORE- O- NAOR kR e A-R BE 
地 址 0) |] http://127. 0.0. 1/php/PHP/PHP_nl2br. php < 输入 关键 词 搜索 MERA dm Osua em 


PHP 基 础 语法 实例 返回 


说 明 

nl2br0 函 数 可 将 字符 串 中 的 找 行 符 转 成 HThL 的 换行 符号 
<?php 

$str =“ 今 天 的 天 气 特别 好 ， 心 情 也 不 错 

， 决定 去 学 校 足球 场 ， 好 好 的 踢 一 场 球 。". 

echo $str; 

echo “<br /»"; 

echo nl2br($str); 

TA 


输出 结果 

今天 的 天 气 特 别 好 ， 心 情 也 不 错 ， 决 定 去 学 校 足 球场 ， 好 好 的 踢 一 场 球 。 
今天 的 天 气 特别 好 ， 心 情 也 不 错 

， 决 定 去 学 校 足 球场 ， 好 好 的 踢 一 场 球 。 


2-11 格式 化 输出 字符 的 结 琳 


// 将 $num 里 的 数值 以 字符 串 的 形式 输出 
printf(" 数 值 为 :9%s",$num); 

echo "<br /> "; 

/转换 成 为 带 有 2 位 小 数 的 浮 点 数 
printf(" 数 值 为 :%.2f",$num); 

echo "<br />"; 

// 解 释 为 整数 并 作为 二 进 制 数 输出 
printf(" 数 值 为 :%b",$num); 

echo "<br /> "; 

HF RAFT 

printf" Z4 [H N : 7% %s",$num); 

2» 


输出 的 结果 如 图 2-712 所 示 。 


2 打印 格式 化 输出 - Nicrosoft Internet Explorer ER) 
文件 人 F) REO SEV KEA IAM WBO IA 
OFE- O- NAOR 44x 6 O-S € 

HEHE M) E] http: //12T. 0. 0. 1/php/FHP/PHP. printf.php 二 输入 关键 词 搜索 ”加 | ERa HE Qst E | 


printf (数值 为 :%. 2£", $num) ; 
echo “<br /5"; 


/ BRE 275 SE e 3 E 26 — Xt tg b 
printf ("39 1B 25 :b", $num) ; 
echo “<br /?"; 


#7 打印 % 符 号 
printf ("数值 为 : 88s", $num) ; 


?» 


输出 结果 
数值 为 :12.8 
数值 为 :12.80 
数值 为 :1100 
数值 为 :%12.8 
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字母 大 小 写 转换 


字母 的 大 小 写 转换 在 PHP 网 页 转换 中 经 香 使 用 到 ， 涉 及 到 的 函数 命令 有 以 下 几 个 第 用 
的 ， 如 strtoupperO 可 以 将 宇 符 串 转 换 成 大 与 字母 ， 将 每 个 单词 的 第 一 个 字母 变 大 写 可 以 使 用 
ucwords0， 将 字符 串 的 第 一 个 字母 转 成 大 写 可 以 使 用 ucfirst0)， 将 字符 串 转 换 成 小 写字 母 可 
以 使 用 strtolowerO。 举 例如 下 。 


<?php 

$str = "I like this game!"; 

/将 字符 串 转 换 成 大 写字 母 

echo strtoupper(Sstr)." «br />"; 
MAFI RRRS "BE 

echo strtolower($str)."<br />"; 

/将 字符 串 的 第 一 个 学 母 转 成 大 与 
echo ucfirst($str)." «br />"; 

/将 每 个 单词 的 第 一 个 字母 变 大 写 
echo ucwords(Sstr); 

2» 


输出 的 结果 如 图 2-13 所 示 。 


A 改 恋 字 母 的 大 小 写 = Nicroso ft Internet Explorer 
TF AEE SAV KEA IA 帮助 H) 
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地 址 0) |] http: //127. 0. 0. 1/php/PHP/php. strUL. php < 输入 关键 词 搜索 M 


说 明 


<?php 

$str = "I like this game!"; 

z/ 将 宇 符 串 转换 成 大 写字 母 

echo strtoupper($str)."4br /?"; 


zz 将 字符 串 转 换 成 小 写字 和 母 
echo strtolower($str)."4br />". 


zy 将 字符 串 的 第 一 个 字母 转 成 太 写 
echo ucfirst($str)."4br /?"; 


/1 将 每 个 单词 的 第 一 个 字母 变 大 写 
echo ucwords($str): 
D 


输出 结果 
| LIKE THIS GAME! 
i like this game! 
| like this game! 
| Like This Game! 


2-13. ”了 字母 转换 大 小 写 结 


泥人 处 理 特殊 的 字符 


有 些 字 和 人 符 对 于 MySQL 是 有 特殊 意义 的 ， 比 如 引号 、 肥 和 斜 杜 和 NULL 字符 。 那 么 如 何 正 
确 处 理 这 些 字 符 呢 ?可 以 使 用 addslashesO 函 数 和 stripslashesQrEZit, PHP 5 中 默认 是 开局 魔 


PHP 编 程 基础 


术 引 号 的 magic_quotes_gpc- 


<?php 

$str = " \"'\ NULL"; 

echo $str."<br />"; 

echo addslashes($str)."<br />"; 
echo stripslashes($str)." <br />"; 
D» 


输出 的 结果 如 图 2-14 Bron 


A 处 理 特 珠 字符 - Nicrosoft Internet Explorer 加 回国 
XED ”编辑 中) 查看 WW) KEAN IAM $8B500 Ld 


QmB-O-[9gmt6 搜索 JSwux 6 e- aBa 
地 址 0) E] http: //127. 0. 0. 1/php/PHP/PHP. adslashes. php -输入 关键 词 搜索 “加 | 国 和 畦 到 链接 Q snt Em 


说 明 

有 些 字 符 对 于 MySQL 是 有 特殊 意 浴 的， 比如 引号 、 吧 斜 杠 和 NULL 字 符 ， 如 何 正确 处 理 这 些 字符 ? 
我 们 可 以 使 用 addslashesj 函 数 和 stripslashes0j 函 数 ， PHP5 中 默认 是 开启 麻 术 引号 的 magic quotes gpce 
<?php 

$str =“ V" A NULL"; 

echo $str."4br />". 

echo addslashes($str)."4br /5"; 

echo stripslashes($str)."4br /?"; 

pr 


输出 结果 
"ANULL 
VY NULL 
"NULL 


(M Internet 


2-14 ”处 理 特殊 的 字符 


dx t SP eg BU [e FH 


在 HTML 中 ， 表 单 拥有 一 个 特殊 功能 : 它们 文 持 交互 作用 。 除 了 表单 乙 外 ， 儿 乎 所 有 
的 HTML 元 素 部 与 设计 以 及 展示 有 关 ， 只 要 愿意 束 可 将 内 容 传 送 给 用 户 。 为 一 方面 ， 表 单 
为 用 户 提供 了 将 信息 传送 回 Web 站 后 创建 者 和 管理 者 的 可 能 性 。 如 果 没 有 表单 ，Web DE 
一 个 静态 的 网 页 图 片 。 对 于 PHP 的 动态 网 页 开发 ， 经 营 过 到 使 用 表单 变量 对 象 ， 通 党 有 
POSTO 和 GETO 两 种 方法 ， 这 和 其 他 动态 语言 开发 的 命令 是 一 样 的 。 本 小 节 束 介绍 表单 变量 
的 使 用 方法 。 


POST B TĘ 


作为 用 于 设置 处 理 表单 数据 的 类 型 ，POST 是 系统 的 默认 值 ， 表 示 将 数据 表单 的 数据 提 
交 到 “动作 ”属性 设置 的 文件 中 进行 处 理 。 假 设 有 一 个 HTML 表单 用 method="post" [77 3X 
传递 给 本 页 一 个 name='"test" 的 文字 信息 ， 可 用 三 种 风格 的 表单 变量 来 显示 这 个 表单 变量 ， 如 
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图 2-15 所 示 。 


<?php 

Echo $test; /简短 格式 , 需 配 置 php.ini 中 的 默认 设置 
echo $ POST["test"]; /中 等 格式 ， 推 荐 使 用 这 种 方式 
echo $HTTP POST VARS['test"]; // 见 长 格式 

7» 


汉 表单 变量 一 Nicrosoft Internet Explorer 
AEG) AmE 查看 人 ”收藏 0) IAT) #6) 


QmB- O-iiztfs sx* wx O A a BL 
地 址 0) Æ] http://127.0.0. 1/php/PHP/PHP formVarpost.php v EJ EE ue O SnagIt ET 


LE, 


<form method-"post" action-""» 

<input type-"text" size-"20" name-"test" /> 
<input type-"submit" value=" fA 3b" /> 
</form> 

<?php 

if(isset($ POST[ test’ ])) 

echo $ POST[' test’ ]: 

Ts 


多 Internet 


图 2-15 POST 表单 测试 


GET 和 POST 的 主要 区 别 是 : 

(1) 数据 传递 的 方式 以 及 大 小 。 

(2) GET 会 将 传递 的 数据 显示 在 url 地 址 上 ，POST 则 不 会 。 
(3) GET 传递 数据 有 限制 ， 一 般 大 量 数据 都 得 使 用 POST 方法 。 


242 GET 表 单 变量 


GET 表示 追加 表单 的 值 到 URL 并 且 发 送 服务 器 请 求 ， 对 于 数据 量 比较 大 的 长 表单 最 好 
不 要 用 这 种 数据 处 理 方式 。 

假设 有 一 个 HIML 表单 用 method="get" 的 方式 传递 给 本 页 一 个 name="test" 的 文字 信 
Al. H 3 种 风格 的 表单 变量 来 显示 这 个 表单 变量 。 


<?php 

Echo $test; /简短 格式 ,需要 配置 php.ini 中 的 默认 设置 
echo $ GET['test"]; /中 等 格式 ， 推 荐 使 用 此 方法 
echo $HTTP GET VARS['test"]; /兄长 格式 

T» 


如 图 2-16 所 示 的 结果 ， 在 TE 地址 栏 里 显示 了 表单 变量 传递 的 值 。 


X258 PHP 编 程 基 础 | 


C 表单 变量 — Microsoft Internet Explorer 
THO 编辑 人 下】 查看 WM REA IAT) *Bh»00 


OAE- O- mia mk rR 6 O-h E C 


<form method="get" action-""»5 

<input type="text” size="20" name-"test" > 
<input type="submit” value-"1E327 35b Eg" /> 
</form> 

<?php 

if (isset ($_GET[ test’ ])) 

echo $ GET[' test]; 

?> 


| 


123456 


(AD Internet 


2-16 GET 表单 测试 


LOS 子 付 串 的 连接 


TE PHP 程序 里 想 让 多 个 字符 种 进行 连接 ， 束 要 用 到 一 个 ()“ 上 点 ”号 ， 来 看 如 下 的 例子 。 


<?php 
$website = "baidu"; 


echo $website.".com"; 
T» 


EAR h RE baidu.com 
有 一 种 情况 ， 当 echo 后 面 使 用 的 是 〈") 双 引 号 ， 可 以 同样 达到 如 上 的 效 末 。 
<?php 


$website = "baidu"; 


echo "$website.com";// 双 引号 里 的 变量 还 是 可 以 正常 显示 出 来 ， 并 和 一 般 的 字符 串 自 动 区 分 开 来 


T> 
fH ar REB. MERKEA REE NFT E E DAR RDU A o 
<?php 


$website = "baidu.com"; 
echo '$website.com'; 
?> 


将 显示 $website.com。 
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量 ， 程 序 才能 对 各 种 值 进行 访问 和 和 运算。 学 习 种 量 和 变量 是 编程 的 基础 。 第 量 和 变量 的 功能 
就 是 用 来 仓储 数据 的 ， 但 区 别 在 于 钊 量 一 旦 初始 化 就 不 再 发 生变 化 ， 可 以 理解 为 符号 化 的 名 


2.5.1 PHP 中 的 常量 | 


常量 是 指 在 程序 执行 过 程 中 无 法 修改 的 值 。 在 程序 中 处理 不 需要 修改 的 值 时 ， 常 量 非常 
有 用 ， 例 如 ， 定 义 圆 周 京 PI。 第 量 一旦 定义 ， 在 程序 的 任何 地 方 都 不 可 以 修改 ， 但 是 可 以 在 
程序 的 任何 地 方 访问 。 

在 PHP 中 使 用 defineO;R AE Xx. RAE 1 个 参数 表示 音量 名 ， 第 2 个 参数 表示 第 
量 的 值 。 

例如 ， 下 面 定义 一 个 名 为 HOST 的 常量 ， 如 图 2-17 所 示 。 


<?php 

define("HOST","www.baidu.com"); // 将 值 “www.baidu.com” 赋 于 常量 HOST 
echo HOST; /输出 HOST 常量 的 值 

?> 


B ^34 一 Nicrosoft Internet Explorer 同上 回国 
E d 
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Q RB - O i] 2) 45 全 搜索 gx 6 A a BL 
地 址 0) |] http: //127. 0. 0. 1/php/PHP/PH?, varCN. php v Essi sm Qs 加 


代码 


<?php 

define ("HOST", “www. baidu. com^) ; CRTE “ww. baidu. com" WE-T X EHOST 
echo HOST; //jíib HOSTS, x 18 

?> 


输出 结果 


waw. baidu.com 


ES 


图 2-17 定义 常量 


种 量 说 明 如 下 。 

向 量 默认 区 分 大 小 写 ， 按 照 惯例 ， 第 量 标识 符 总 是 大 写 。 弟 量 名 和 其 他 任何 PHP 标记 
遵循 相同 的 命名 规则 。 合 法 的 常量 名 以 字母 或 下 夯 线 开始 ， 后 面 跟 任何 字母 、 数 字 或 下 面 
线 。 

PHP 的 系统 常量 包括 5 个 魔术 和 常量 和 大 量 的 预定 义 沿 量 。 

魔术 常量 会 根据 使 用 的 位 置 而 改变 ，PHP 提供 的 5 个 魔术 常量 分 别 是 : 

C) LINE : 表示 文件 中 的 当前 行 号 。 

(2) HLE : 表示 文件 的 完整 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 文件 
名 。 自 PHP 402 起 ，_FILE 总 是 包含 一 个 绝对 路 径 ， 而 在 此 之 前 的 版 本 有 时 会 包含 一 个 相 


第 2 音 QES 


对 路 径 。 
(3) FUNCTION : 表示 函数 名 称 (PHP 4.3.0 新 加 )。 自 PHP 5 起 本 常量 返回 该 函数 
被 定义 时 的 名 字 《〈 区 分 大 小 写 )。 在 PHP4 中 该 值 总 是 小 写字 母 的 。 
(4) CLASS: 表示 类 的 名 称 (PHP 4.3.0 SUED. H PHP5 起 本 常量 返回 该 类 被 定义 e) 
时 的 名 字 (区 分 大 小 写 )。 在 PHP4 中 该 值 总 是 小 写字 母 的 。 | 
(5) METHOD : 表示 类 的 方法 名 (PHP 5.0.0 新 加 )。 返 回 该 方法 被 定义 时 的 名 字 
《区分 大 小 写 为 
预定 义 常 量 又 分 为 内 核 预 定义 常量 和 标准 预定 义 常 量 两 种 ， 内 核 预 定义 常量 在 PHP 的 
内 核 、Zend 引擎 和 SAPI 模块 中 定义 ， 而 标准 预定 义 常 量 是 PHP 默认 定义 的 ， 比 如 常用 
的 E_ERROR、FE_NOTICE、E_ALL 等 。 


_PHP 中 的 变量 


在 PHP 中 ， 创 建 一 个 变量 首先 需要 定义 变量 的 名 称 。 变 量 名 区 分 大 小 写 ， 总 是 以 $ 符 号 
开头 ， 然 后 是 变量 名 。 如 果 在 声明 变量 时 ， 访 记 变 量 前 面 的 $ 符 号， 那么 该 变量 将 无 效 。 在 
PHP 中 设置 变量 的 正确 方法 如 下 所 示 。 


$var name = value; 


在 PHP 中 ， 可 以 使 用 值 赋值 和 引用 赋值 这 两 种 方法 为 变量 赋值 。 
值 赋值 是 下 接 把 一 个 数值 通过 赋值 表达 式 传递 给 变量 。 值 赋值 是 一 种 党 量 的 变量 冉 值 的 
方法 ， 其 使 用 格式 如 下 所 示 。 


<?php 

$name = "baidu"; IF IURE c 

$Name = "website"; IF IURE c 

echo "$name, $Name"; // 输 出 为 “baidu, website " 
$1website 2 "www.baidu.com"; /无 效 变 量 ， 以 数字 开始 
$_1website = "www.baidu.com'"; /有 效 变量 

2» 


从 上 述 代 码 中 可 以 看 到 ， 在 PHP 中 不 需要 在 设置 变量 之 前 声明 该 变量 的 类 型 ， 而 是 根 
所 变量 被 设置 的 方式 ，PHP 会 日 动 把 变量 转换 为 正确 的 数据 类 型 。 

Æ PHP 中 ， 变 量 的 命名 规则 有 如 下 儿 点 。 

(1) 变量 名 必须 以 字母 或 下 面 线 "_" 开 头 。 

(2) 变量 名 只 能 包含 字母 、 数 字 、 字 符 以 及 下 画 线 。 

(3) 变量 名 不 能 包含 空格 。 如 果 变 量 名 由 多 个 单词 组 成 ， 那 么 应 该 使 用 下 画 线 进行 分 隔 
(例如 $my_string)， 或 者 以 大 写字 母 开 头 〈 例 如 $myString )。 

Æ PHP 中 ， 还 文 持 另 一 种 赋值 方式 ， 称 为 变量 的 引用 赋值 ， 例 如 下 面 的 示例 。 


<?php 
$wo = 'baidu'; /为 变量 $wo 赋值 
$ba = &$wo; // 取 变量 $ba 引用 了 变量 $wo 的 值 


PHP+ 
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$ba = "Web site is $ba"; /修改 变量 $ba 的 值 
echo $wo; // 结 果 为 “Web site is baidu” 
echo $ba; /变量 $ba 的 值 也 被 修改 ， 结 果 与 $ba 相同 


?> 
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变量 的 引用 赋值 导致 两 个 变量 指向 同一 个 内 存 地 址 。 因 此 ， 不 论 对 哪 一 个 变量 进行 修改 ， 修 
改 的 是 同一 个 内 存 地 址 中 的 数据 ， 从 而 出 现 同时 被 修改 的 结 

PHP 提供 了 大 量 的 预定 义 变量 ， 这 些 变 量 在 任何 范围 内 目 动 生效 ， 因 此 通 钊 也 被 称 为 目 
动 全 局 变量 (autoglobals) 或 者 超 全 局 变量 Csuperglobals) (PHP 中 没有 用 户 目 定义 超 全 局 变 
量 的 机 制 )。 在 PHP 4.1.0 之 前 ， 如 使 用 超 全 局 变量 ， 要 么 依赖 register_globals, 9i LAE 
长 的 预定 义 PHP 数组 〈$HTTP * _ VARS)。 目 PHP 5.0.0 起 ， 长 格式 的 PHP 预定 义 变量 可 
以 通过 设置 register long. arrays X B£ Mto 

种 用 的 超 全 局 变量 如 下 。 

(1) $GLOBALS: 表示 包含 一 个 引用 指 辐 每 个 当前 脚本 的 全 局 范围 内 有 效 的 变量 ， 该 数 
组 的 键 名 为 全 局 变量 的 名 称 。 从 PHP 3 开始 存在 $GLOBALS 数组 。 

(2) $ SERVER: 表示 变量 由 Web 服务 堪 设 定 或 者 直接 与 当前 脚本 的 执行 环境 相关 联 ， 
类 似 于 旧 数 组 $HTTP_SERVER_VARS 数组 (依然 有 效 ， 但 反对 使 用 )。 

(3) $ GET: 表示 经 由 URL 请 求 提交 全 脚本 的 变量 ， 类 似 于 旧 数 组 SHTTP_GET_VARS 
数组 (依然 有 效 ， 但 反对 使 用 )。 

(4) $_POST: 表示 经 由 HTTP POST 方法 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 $HTTP _ 
POST VARS 数组 (依然 有 效 ， 但 反对 使 用 )。 

(5) $ COOKIE: 表示 经 由 HTTP COOKIE 方法 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 
$HTTP_COOKIE_VARS 数组 (依然 有 效 ， 但 反对 使 用 )。 

(6) $_FILES: 表示 经 由 HTTP POST 文件 上 传 而 提交 全 脚本 的 变量 。 类 似 于 旧 数 组 
$HTTP_POST_FILES 数组 (依然 有 效 ， 但 反对 使 用 )。 

CI) $ ENV: 表示 执行 环境 提交 全 脚本 的 变量 ， 类 似 于 旧 数 组 SHTTP_ENV_VARS 数组 
(依然 有 效 ， 但 反对 使 用 )。 

(8) $ REQUEST: 表示 经 由 GET. POST 和 COOKIE 机 制 提 交 人 至 脚本 的 变量 ， 因 此 该 
数组 并 不 值得 信任 。 所 有 包含 在 该 数组 中 的 变量 的 存在 与 否 以 及 变量 的 顺序 均 按 照 php.ini 
中 的 variables order 配置 指示 来 定义 。 此 数组 在 PHP 4.1.0 之 前 没有 直接 对 应 的 版 本 。 

(9) $ SESSION: 表示 当前 注册 给 脚本 会 话 的 变量 ， 类 似 于 旧 数 组 $HTTP_ SESSION - 
VARS 数组 (依然 有 效 ， 但 反对 使 用 )。 


| PHP 数据 类 型 


数据 是 程序 运行 的 基础 ， 所 有 的 程序 都 是 在 处 理 各 种 数据 。 例 如 ， 财 务 统计 系统 所 要 处 
理 的 员工 工资 额 、 论 坛 程序 所 要 处 理 的 用 户 名 、 密 码 、 用 户 发 帖 数 等 等 ， 所 有 这 些 虱 是 数 
据 。 在 编程 语言 中 ， 为 了 方便 对 数据 的 处 理 以 及 市 省 有 限 的 内 容 资 源 ， 需 要 对 数据 进行 分 
Ro PHP 文 持 7 种 原始 类 型 ， 分 别 有 如 下 儿 种 。 
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(1) boolean 〈 布 尔 型 True/False). 
(2) integer (整数 类 型 )。 
(3) float 〈 浮 点 型 ， 也 称 为 double， 可 用 来 表示 实数 )。 | 
(4) string CFI RRA). c 
(5) array《〈 数 组 同一 变量 保存 同类 型 的 多 条 数据 )。 
(6) object OR 23). 
CI) 特殊 类 型 (resource 资源 和 NULL ZR EE AE. 
下 面 介绍 第 用 的 数据 次 型 。 
1. 布尔 型 boolean 
布尔 型 是 最 简单 的 类 型 ， 它 表达 了 真 值 ， 可 以 为 True 或 False。 要 指定 一 个 布尔 值 ， 使 
用 关键 学 True 或 False, J£ H. True 或 False 不 区 分 大 小 写 。 例 如 : 
$pay = True; // 给 变量 $pay 赋值 为 True 
某 些 运算 通 钟 返回 布尔 值 ， 并 将 其 传递 给 控制 流程 。 比 如 用 比较 运算 符 〈==) 来 比较 两 
个 运算 数 ， 如 果 相 等 ， 则 返回 True, URIE] False， 代 人 码 如 下 : 


if ($A — $B) { 
echo "$A 与 $B 相等 "; 
} 


对 于 如 下 的 代码 : 


if ($pay == True) { 
echo "已 付 "; 
j 


aJ EH PIETRA: 
if ($pay) { 


echo" Bf} "; 
} 


转换 成 布尔 型 用 bool 或 者 boolean 来 强制 转换 。 但 是 很 多 情况 下 不 需要 用 强制 转换 ， 
为 当 运 算 符 、 函 数 或 者 流程 控制 需要 一 个 布尔 参数 时 ， 访 值 会 被 目 动 转换 。 

当 转 换 为 布尔 型 时 ， 以 下 值 被 认为 是 False。 

(1) 布尔 值 False。 

(20 整 型 值 0 CE. 

(3) PEU 0.0 (E). 

(4) 衬 日 字符 串 和 字符 串 "0"。 

(5) 没有 成 员 变 量 的 数组 。 

(6) 没有 单元 的 对 象 〈 仅 适用 于 PHP 4)。 

CI) 特殊 类 型 NULL (包括 尚未 设 定 的 变量 )。 

所 有 其 他 值 都 被 认为 是 True〈 包 括 任何 资源 )。 
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2. 整 型 integer 

一 个 整数 是 集合 Z={…, -2, -1 0, 1, 2,…} 中 的 一 个 数 。 整 型 值 可 以 用 十 进 制 、 十 六 进 
制 或 八进制 表示 ， 前 面 可 以 加 上 可 选 的 符号 (- 或 者 +)。 如 果 用 八进制 ， 数 学 前 必须 加 上 0 
CHE 用 十 六 进 制 ， 数 字 前 必须 加 上 0x。 整 型 数 的 字 长 和 平台 有 关 ， 通 第 最 大 值 是 大 约 二 十 
4L (32 位 有 符号 )。PHP 不 文 持 无 符 亏 整数 。 如 果 给 定 的 一 个 数 超 出 了 整 型 的 范围 ， 将 会 被 
解释 为 浮 点 型 ， 同 样 如 果 执 行 的 运算 结果 超出 了 整 型 范围 ， 也 会 返回 浮 点 型 。 

要 将 一 个 值 转换 为 整 型 ， 用 int 或 integer 强制 转换 即 可 。 不 过 大 多 数 情况 下 都 不 需要 强 
制 转换 ， 因 为 当 运 算 符 、 函 数 或 流程 控制 需要 一 个 整 型 参数 时 ， 访 值 会 日 动 转换 。 还 可 以 通 
过 函数 intval0 来 将 一 个 值 转换 成 整 型 。 

从 布尔 型 转换 成 整 型 ，False 将 产生 出 0，True 将 产生 出 1。 当 从 浮 点 数 转 换 成 整数 时 ， 
数字 将 被 取 整 《丢弃 小 数位 )。 如 果 浮 点 数 超出 了 整数 范围 ， 则 结果 不 确定 ， 因 为 没有 足够 
的 精度 使 浮 点 数 给 出 一 个 确切 的 整数 结果 。 

3. 浮 点 型 float 

浮 点 数 也 叫 双 精 度数 或 实数 ， 可 以 用 以 下 任何 语法 定义 : 

<?php 
$a = 1.234; 
$b = 1.2e3; 
$c = 7E-10; 
7» 


VEIESGBRITXHKGUESHMBA. XI AHie18e308. HHA 14 位 十 进 制 数字 的 精度 。 

4. 字符 串 string 

字符 串 是 由 引号 括 起 来 的 一 些 字 符 ， 凋 用 来 表示 文件 名 、 显 示 消 息 、 输 入 提示 符 等 。 字 
符 串 是 一 系列 字符 ， 字 人 符 串 的 大 小 没有 限制 。 字 符 串 可 以 用 单 引 号 、 双 引号 或 定 界 符 3 种 方 
法 定义 。 下 面 分 别 介绍 这 3 种 方法 。 

(1) 单 引 号 。 指 定 一 个 简单 字符 串 的 最 简单 的 方法 是 用 单 引 号 〈") 括 起 来 。 例 如 : 
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<?php 
echo 'Hello World '; / 输出 为 : Hello World 
2» 


如 果 字 符 串 中 有 单 引 号 ， 要 表示 这 样 一 个 单 引 号 ， 和 很 多 其 他 语言 一 样 ， 需 要 用 反 和 斜 线 
A) 转 义 。 例 如 : 
<?php 


echo 'IV m Tom'; // 输出 为 : Pm Tom 
T5 
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未 。 例 如 : 


<?php 
echo 'Path is c:\windows\system\\'; // 输出 为 : Path is c:\windows\system\ 
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?> 


对 于 单 引 写 CO MEFE, PHP 只 懂得 单 引号 和 反 斜 线 的 转 义 序列 。 如 末 试 图 转 义 


任何 其 他 字符 ， 反 和 鲜 线 本 映 也 会 被 显示 出 来 。 为 外 ， 人 还 有 不 同 于 双 引 号 和 定 界 符 的 很 重要 的 
一 扣 束 是 ， 单 引 写 子 符 串 中 出 现 的 变量 不 会 被 解析 。 © 
(2) 双 引 写 。 如 果 用 双 引 写 《") 括 起 子 符 串 ，PHP EREEREER XY C 


X 2-1)。 
表 2-1 转 义 字符 
序 “ 列 含 X 

n 美元 符号 

Ww 双 3 引 号 

" 此 正则 表达 式 序列 匹配 一 个 用 八进制 表 
示 的 字符 

此 正则 表达 式 序列 匹配 一 个 用 十 六 进 制 
表示 的 字符 


如 末 试 图 转 义 任何 其 他 字符 ， 反 和 斜 线 本 喘 也 会 被 显示 出 来 。 双 引号 字符 串 最 草 要 的 一 点 
是 能 够 解析 其 中 的 变量 。 
(30 定 界 符 。 另 一 种 给 字符 溃 定 界 的 方法 是 使 用 定 界 符 语 法 〈<<<)。 应 该 在 <<< 之 后 提 
供 一 个 标 误 从， 接 看 古 子 符 串 ， 然 后 是 同样 的 标识 答 结 束 子 符 串 。 例 如 : 
<?php 
/ 输出 为 : Hello World 
echo <<<abc 
Hello World 
abc; 
2» 
在 此 段 代码 中 ， 标 识 符 命名 为 abc。 结 束 标识 得 必 须 从 行 的 第 一 列 开始 。 标 识 符 所 如 循 
的 命名 规则 是 上 只 能 包含 字母 数字 下 画 线 ， 而 且 必 须 以 下 画 线 或 非 数 学 字符 开始 。 
定 界 符 文 本 表现 的 承 和 双 引 号 字符 串 一 样 ， 只 是 没有 双 引 号 。 这 意味 痢 在 定 界 符 文 本 中 
不 需要 转 义 引号 ， 不 过 仍然 可 以 用 以 上 列 出 的 转 义 代码 ， 变 量 也 会 家 解析。 在 以 上 的 3 种 定 
义 字 符 串 的 方法 中 ， 奋 使 用 双 引 号 或 者 定 界 符 定 义 衬 符 串 ， 其 中 的 变量 会 被 解析 。 
5. 数组 array 
PHP 中 的 数组 实际 上 是 一 个 有 序 图 ， 图 是 一 种 把 value 映射 到 key 的 类 型 。 痢 建 一 个 数 
组 使 用 array0O 语 言 结构 ， 它 接受 一 定数 量 用 过 号 分 隔 的 key => value 参数 对 。 
语法 如 下 : 


array( [ key => ] value , … ) 


Hp, WE key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 ， 如 果 值 又 是 一 个 数 
组 ， 则 可 以 形成 多 维 数组 的 数据 结构 。 例 如 : 


<?php 
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$edName = array(0 => "id", 1=>"username", 2-2» "password"); 
echo " 列 名 是 $edName[0]，$edName[1]，$edName[2]": 
2» 


此 段 代 人 码 的 输出 为 : F4 XE id. username. password. 
如 果 省 略 了 键 key， 会 目 动 产生 从 0 开始 的 整数 索引 。 上 面 的 代码 可 以 改写 为 : 
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<?php 

$edName = array("id", "username", "password"); 

echo " 列 名 是 $edName[0]，$edName[1]，$edName[2]": 
T» 


此 段 代 人 码 的 输出 仍 为 : FUA IE id. username. password. 
如 末 key 是 整数 ， 则 下 一 个 产生 的 key 将 是 目前 最 大 的 整数 索引 加 1。 如 来 指定 的 键 已 
经 有 了 值 ， 则 新 值 会 履 盖 旧 值 。 再 次 改写 上 面 的 代码 为 : 


<?php 
$edName = array(1=>"id", "username", "password"); 
echo " 列 名 是 $edName[1]，$edName[2]，$edName[3]": 
jo. 


此 段 代 人 码 的 输出 仍 为 : FUA IE id. username. password. 

定义 数组 的 另 一 种 方法 是 使 用 方 括号 的 语法 ， 通 过 在 方 括号 内 指定 键 为 数组 赋值 来 实 
现 。 也 可 以 省 略 键 ， 在 这 种 情况 下 给 变量 名 加 上 一 对 至 的 方 括号 〈[])。 

语法 如 下 : 


$arrayName[key] = value; 
$arrayName [] = value; 


其 中 ， 键 key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 。 例 如 : 


<?php 

$edName[0]= "id"; 

$edName[1]2 "username"; 

$edName[2]- "password"; 

echo "Z4 Xé$edName[0], $edName[1]. $edName[2]"; 
7> 


此 段 代 人 码 的 输出 仍 为 : PAE id. username, password. 

如 条 给 出 方 括号 但 没有 指定 键 ， 则 取 当 前 最 大 整数 索引 值 ， 新 的 键 将 是 该 值 加 1。 如 末 
当前 还 没有 整数 索引 ， 则 键 将 为 0。 如 采 指 定 的 键 已 丝 有 值 了 ， 访 值 将 被 畴 兰 。 

对 于 任何 的 类 型 一 一 布尔 、 整 型 、 浮 点 、 了 字符 串 和 资源 ， 如 果 将 一 个 值 转换 为 数组 ， 将 
得 到 一 个 仅 有 一 个 元 素 的 数组 (其 下 标 为 0)， 该 元 素 即 为 此 标量 的 值 。 如 果 将 一 个 对 象 转 
换 成 一 个 数组 ， 所 得 到 的 数组 的 元 素 为 该 对 象 的 属性 (成 员 变 量 )， 其 键 为 成 员 变 量 名 。 如 
果 将 一 个 NULL 值 转换 成 数组 ， 将 得 到 一 个 空 数组 。 
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6. 对 象 object 

使 用 class 定义 一 个 类 ， 然 后 使 用 new 类 名 构造 函数 参数 ) 来 初始 化 类 的 对 象 。 该 数 
据 类 型 将 在 后 面 的 实例 中 具体 应 用 进行 解析 。 

7. 其 他 数据 类 型 

除了 以 上 介绍 的 6 种 数据 类 型 ， 还 有 资源 和 NULL 两 种 特殊 类 型 ， 下 面 简单 介绍 一 下 资 
源 和 NULL 两 种 特殊 类 型 。 

(1) 资源 。 资 源 是 通过 专门 函数 来 建立 和 使 用 的 一 个 特殊 变量 ， 保 存 了 外 部 资源 的 一 个 
引用 。 可 以 保存 打开 文件 、 数 据 库 连接 、 图 形 画 布 区 域 等 的 特殊 句柄 ， 无 法 将 其 他 类 型 的 值 
转换 为 资源 。 资 源 大 部 分 可 以 被 系统 自动 回收 。 

(2) NULL. NULL 类 型 只 有 一 个 值 ， 束 是 区 分 大 小 写 的 关键 学 NULL。 特 殊 的 NULL 
值 表示 一 个 变量 没有 值 。 

在 下 列 情况 下 ， 一 个 变量 被 认为 是 NULL。 

(1) 被 赋值 为 NULL。 

(2) 尚未 被 赋值 。 

(3) 被 unsetO。 

例如 : 


<?php 
$php = 
if(isset($a)) 

echo *[1] is NULL<br>” ; 
$php = 0; 

if(isset($a)) 

echo “[2] is NULL«br* " ; 
$php = NUII; 

if(isset($a)) 

echo ^[3] is NULL«br* " ; 
$php = FALSE; 
if(isset($a)) 

echo *[4] is NULL«br^ " ; 
2» 


结果 是 什么 ? 

在 3 种 情况 下 ， 变 量 被 认为 是 空 值 。 

(1) 变量 没有 被 赋值 。 

(2) 变量 被 赋值 为 NULL，0，False 或 者 空 字符 串 。 
(30 变量 在 非 至 值 的 情况 下 ， 被 unset 函数 释放 。 


数据 类 型 转换 


在 PHP 中 寿 要 进行 数据 类 型 的 转换 ， 残 要 在 转换 的 变量 之 前 加 上 用 括 写 括 起 来 的 目标 类 
型 。 在 变量 定义 中 不 需要 显 式 的 类 型 定义 ， 变 量 类 型 是 根据 使 用 该 变量 的 上 下 文 所 决定 的 。 


Y . 


© 


PHP-* 
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例如 ， 通 过 类 型 的 转换 ， 可 将 变量 或 其 所 附带 的 值 转换 成 为 外 一 种 类 型 ， 如 图 2-18 


所 示 。 
<?php 
$num = 123; // 当 前 是 整数 类 型 
$float = (float)$num; /$num 临时 性 ”地 转换 成 了 浮 点 型 ，$float 变量 所 携带 的 数据 类 型 就 为 浮 点 
型 
echo gettype($num)." «br />";// 使 用 gettype(mixed var) 函 数 来 获取 变量 类 型 
echo gettype($float) 
2» 
E] PHP 变 量 类 型 转换 一 Nicroso ft Internet Explorer 
文件 他) 编辑 于 ) EQ) 收藏) IAM) RH aw 
QAE- O- harr wx O6 ee- LBL 
地 址 部 ) Æ] http: //127.0.0. l/php/PHP/PHP var type change. php AE iiis © SnagIt E 
<?php 
$num = 123; 
$float = (float) $num; 
echo gettype ($num). "<br />" :// H gettype (mixed var) 团 数 来 获取 变量 类 型 
echo gettype($float) 
?> 
输出 结果 
integer 
double 
aze 
图 2-18 ”数据 类 型 的 转换 
提示 : 


如 要 将 一 变量 彻底 转换 成 另 一 种 类 型 ， 就 要 使 用 settype(mixed var, string type) Až. 
允许 的 强制 转换 有 如 下 几 种 。 

(I) int, integer: 转换 成 整 型 。 

(2) bool. boolean: 转换 成 布尔 型 。 

(3) float、double、real: 转换 成 浮 点 型 。 

(4) string: 转换 成 字符 串 。 

(5) array: 转换 成 数组 。 

(6) object: 转换 成 对 象 。 


XL 
ir 


Section - 


PHP 中 的 运算 符 


对 于 学 过 其 他 语言 的 读者 ， 运 算 符 应 该 不 会 阳 生 了 。 运 算 符 可 以 用 来 处 理 数 字 、 字 符 吓 
及 其 他 比较 运算 和 所 辑 运 算 等 。 在 PHP 中， 运算 符 两 侧 的 操作 数 会 目 动 地 进行 类 型 转换 ， 
这 在 其 他 的 编程 语言 中 并 不 多 见 。 在 PHP 的 编程 中 主要 有 以 下 3 种 类 型 的 运算 符 。 

(D 一 元 运算 符 。 只 运算 一 个 值 ， 例 如 : !〈 取 反 运 算 符 ) 或 ++ (加 一 运算 符 )。 
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(2) 二 元 运算 待 。PHP 文 持 的 大 多 数 运算 符 都 是 这 种 ， 例 如 : $a + $b。 

(30 三 元 运算 待 。 即 ?， 它 被 用 来 根据 一 个 表达 却 在 妃 两 个 表达 陈 中 选择 一 个 ， 而 不 是 
用 来 在 两 个 语句 或 者 程序 路 线 中 选择 。 

PHP 中 向 用 运算 符 有 算术 运算 待 、 赋 值 运算 符 、 比 较 运 算 待 、 三 元 运算 符 、 错 误 控 制 运 
算 全 、 迪 辑 运算 人行 、 子 符 串 运算 全、 数组 运算 从 等 。 本 节 就 主要 介绍 第 用 的 运算 符 ， 以 及 运 
算 符 的 优先 级 。 


E sut 


算术 运算 符 是 用 来 处 理 四 则 运算 的 符号 ， 是 最 简单 、 也 最 各 用 的 符号 ， 尤 其 是 数字 的 处 
理 ， 几 乎 都 会 使 用 到 算术 运算 符号 。PHP 的 算术 运算 符 如 表 2-2 Bp. 


42-2 算术 运算 符 


$a 的 负 值 


cI 


z -a 

+ $a + $b $a 和 $b 的 和 

- $a — $b $a 和 $b HZ 

s $a * $b $a 和 $b 的 积 

/ $a / $b $a 除 以 $b 的 商 
% $a 96 $b $a 除 以 Sb 的 余数 
++ $a ++ $a 的 累加 

x $a—— $a 的 递减 


注意 ， 除 号 CO 总 是 返回 浮 点 数 ， 即 使 两 个 运算 数 是 整数 〈 或 由 字符 串 转 换 成 的 整 
数 ) 也 是 这 样 。 
赋值 运算 符 


赋值 运算 符 (Assignment Operator) 把 表达 式 右 边 的 值 赋 给 左边 变量 或 常量 。 其 本 的 
赋值 运算 符 是 =， 它 意味 看 把 右边 表达 式 的 值 贱 给 左边 的 运算 数 。PHP 中 的 赋值 运算 符 如 
X 2-3 所 示 。 


表 2-3 赋值 运算 符 


符 号 m — di 意 X 
= $a = $b 将 右边 的 值 连 到 左边 
+= $a += $b 将 右边 的 值 加 到 左边 ， 即 $a = $a + $b 
-= $a -= $b 将 右边 的 值 减 到 左边 ， 即 $a = $a 一 $b 
t= $a *= $b 将 左边 的 值 乘 以 右边 ， 即 $a = $a * $b 


$a /=$b 将 左边 的 值 除 以 右边 ， 即 $a = $a/ $b 


PHP-* 


不 例 
$a 96 $b 


$a .= $b 


在 基本 赋值 运算 符 之 外 ， 还 有 适合 于 所 有 二 元 算术 和 字符 串 运 算 符 的 “组 合 运 算 符 ”， 
这 样 可 以 在 一 个 表达 式 中 使 用 它 的 值 并 把 表达 式 的 结 末 赋 给 它 ， 例 如 : 


<?php 

$a ="baidu"; 
$b =".com"; 
echo $a .= $b; 
je 


运行 结果 如 图 2-19 所 示 。 


Im 
Ac 


将 左边 的 值 除 对 右边 取 余 数 ， 即 $a = $a 96 $b 
将 右边 的 字 串 加 到 左边 ， 即 $a = $a. $b 
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A 贼 值 探 作 符 一 Nicrosoft Internet Explorer 
文件 他) 编辑 偿 ) 查看 人 ”收藏 以 ) 工具 民 ) Bw) 


OAE- OQ-ixizf» Js JUS € 0- qc 


地 址 0) E http://12T.0.0. 1/php/PHP/PHP_dvar. php č — 


代码 


<?php 

$a -"baidu"; 
$b =“. com"; 
echo $a .= $b; 
T 


输出 结果 


baldu.com 


ES 


D Internet 


图 2-19 赋值 运算 字符 串 结 果 


cou 比较 运算 符 


比较 操作 符 ， 顾 名 思 义 就 是 可 用 来 比较 的 操作 符号 
绞 运 算 符 ， 人 允许 对 两 个 值 进行 比较 ，PHP 的 比较 运算 符 如 表 2-4 所 示 。 


表 2-4 比较 运算 符 


不 例 

$a== $b True, 
$a===$b True, 

$a != $b True, 

$a <> $b True, 


èi 
xz 


如 果 $a 等 于 $b 


EEx) 
L7 


v Ejss sm Qst im 


， 根 据 结果 来 返回 True 或 False. LU 


WR $a 等 于 $sb， 并 且 它 们 的 类 型 也 相同 


如 果 $a 不 恒 等 于 $b 
如 果 $a 不 等 于 $b 


未 4j 名 称 
$a != = $b 非 全 等 
$a < $b 小 于 
$a > $b XT 
$a <= $b 小 于 等 于 
$a >= $b 大 于 等 于 
三 元 运算 符 


三 元 运算 符 是 ?2:， 三 元 运算 符 的 功能 和 if.. 


(exprl1) ? (expr2) : (expr3) 


True, 


True, 


True, 


True, 


True, 
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I-A y 
F X. 


如 果 $a 不 等 于 $， 或 者 它们 的 类 型 不 同 PHP 4 引进 ) 

如 果 $a 严格 小 于 $b c 
如 果 $a 严格 大 于 $b 

如 果 $a 小 于 或 者 等 于 $b 

WR $a 大 于 或 者 等 于 $b 


else 语句 很 相似 ， 语 法 如 下 : 


首先 对 exprl 求 值 ， 硅 结果 为 True， 则 表达 式 (expr1) ? (expr2) : (expr3) 的 值 为 expr2， 合 


则 其 值 为 expr3。 例 如 : 


<?php 


$action = (empty($ POSTY['action'])) ? 'default' : $ POST['action']; 


2» 


首先 判断 $_POST[action] 变 量 是 否 为 宇 值 ， 大 是 ， 则 给 $action 赋值 为 default， 人 否则 将 
$_POST['action] 变 量 的 值 赋值 给 $action。 可 以 将 上 面 的 代码 改写 成 以 下 的 代码 : 


<?php 
if (empty($ POST['action'])) { 
$action = 'default'; 
) else ( 
$action = $ POST[action']; 


2» 


错误 控制 运算 符 


错误 控制 操作 符 (@) 可 在 任何 表达 式 前 使 用 ，PHP 文 持 一 个 错误 控制 运算 从 @。 当 将 其 
放置 在 一 个 PHP 表达 式 之 前 ， 访 表达 式 可 能 产生 的 任何 错误 信息 都 被 忽略 挥 。@ 运 算 从 只 对 


表达 式 有 效 。 


那么 ， 何 时 使 用 此 运算 符 昵 ? 一 个 简单 的 规则 就 是 ， 如 果 能 从 某 处 得 到 值 ， 吏 能 在 它 瑶 
面 加 上 @ 运 算 符 。 例 如 ， 可 以 把 它 放 在 变量 、 函 数 和 include0 调 用 、 常 量 等 之 前 。 不 能 把 它 
放 在 函数 或 类 的 定义 之 前 ， 也 不 能 用 于 条 件 结构 ， 例 如 ff 和 foreach 等 。 


对 于 如 下 的 代码 : 


<?php 
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"on "on 


$Conn- mysql connect ("localhost"," username" ,"pwd"); 
if ( SConn) 
echo "连接 成 功 ! "; 
else 
echo "连接 失败 ! "; 
2» 


如 果 mysql_connectO0 连 接 失 败 ， 将 显示 系统 的 错误 提示 ， 而 后 继续 执行 下 面 的 程 


序 。 如 果 不 想 显示 系统 的 错误 提示 ， 并 希望 失败 后 立即 结束 程序 ， 则 可 以 改写 上 面 的 代 
B F: 


<?php 
$Conn = @mysql_connect ("localhost","username","pwd") or die ("连接 数据 库 服 务 器 出 错 "); 
?> 


在 mysql. connectO K ZAT IE exe SPEAK BECAS ZH E vez S. AAEH die0 函 数 给 出 
目 定 义 的 错误 提示 ， 然 后 立即 退出 程序 。 这 种 用 法 在 大 型 程序 中 很 常见 。 


逻辑 运算 符 
PHP 的 逻辑 运算 从 (Logical Operators) 通常 用 来 测试 真 假 值 ， 和 常用 的 逻辑 运算 符 如 
dé 2-5 Wr. 
X 2-5 人 逻辑 运算 符 

and $a and $b 如 果 $a 与 $b 都 为 True 

or $a or $b 如 果 $a 或 $b 任 一 为 True 

XOr $a xor $b 如 果 $a 或 $b 任 一 为 True， 但 不 同时 是 
如 果 $a 不 为 True 
如 果 $a 与 $b 都 为 True 


如 果 $a 或 $b 任 一 为 True 


“与 ”和 “或 ”有 两 种 不 同形 式 运 筑 符 ， 它 们 运算 的 优先 级 不 同 ， 信 区 和 | 优先 级 高 。 


字符 串 运 鼻 符 


字符 串 运算 从 (String Operator) 有 两 个 字符 串 运 算 符 。 第 一 个 是 连接 运算 符 CO), CR 
回 其 左右 参数 连接 后 的 字符 串 。 第 二 个 是 连接 赋值 运算 从 〈(.=)， 它 将 右边 参数 附加 到 左边 
的 参数 后 面 。 

例如 : 
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<?php 
$a = "你 好 "; 
$a = $a . "朋友!";/W/ 此 时 $a 是 "你 好 朋友 
$b=" 你 好 “"; | 
$b .= "朋友 !"; /此 时 $b 是 "你 好 朋友 ©) 
i» 

数组 运算 付 ) 


PHP 的 数组 运算 符 ， 如 表 2-6 所 示 。 


42-6 数组 运 鼻 符 


符号 m i E X 
i $a 和 $b 的 联合 ， 返 回 包含 了 $a 和 Sb 中 所 有 元 素 的 数组 
Ži $a == $b 如 果 $a 和 $b 具有 相同 的 元 素 ， 就 返回 True 
Ts 两 者 具有 相同 元 素 且 顺序 相同 ， 返 回 True 
!= $a != $b 如 果 $a 和 $b 不 是 等 价 的 ， 就 返回 True 
m 如 果 $a 不 等 于 $b， 就 返回 True 
== $a != = $b 如 果 $a 和 $b 不 是 恒 等 的 ， 就 返回 True 


联合 运算 符 《+) 把 右边 的 数组 附加 到 左边 的 数组 后 面 ， 但 古 香 复 的 键 值 不 会 被 履 诲 。 
下 和 面 通过 一 个 实例 来 看 一 下 如 何 用 + 运算 从 联合 两 个 数组 : 


<?php 

$a = array("1"=>"No1", 
"2'2»"No2", 
"3"=>"No3", 
"4"=>"No4"); 


$b = array("3"=>"No3", 
"4"=>"No4", 
"5"=>"No5", 
"6"-»"No6"); 

$c = $a+$b; 

print. r($c); /联合 两 数组 
echo "<br /»"; 

if($a--$b) 

echo "等 价 "; 
else 

echo "不 等 价 "'; 


?> 


可 以 看 到 ， 在 联合 之 后 的 数组 结 来 如 图 2-20 TR o 


" rHr Tg Microsoft Internet Explurer 

vo) aug) XE) SR 工具 Won 

Qm-oO0- HAG s ER € O- h 

AET) A8] hatg: 7127. 0.0. TT array en. pho — xpuwr [Eee um Quan p 


( [1] = Not [2] = Ne2 [3| => No3 [4] => Ned [5] => No5 [6] => Nob ) 


TG 


I Internat 


图 2-20 ”联合 数组 示例 


zoo 运算 符 的 优先 级 


运算 符 优 先 级 指定 了 两 个 表达 却 绑 定 得 有 多 “紧密 ”。 例 如 ， 表 达 了 式 1 + 2 * 31m: 47e 
7 而 不 是 9 EDDA Co 的 优先 级 比 加 号 O m. QE RI ELS orm lee poc 
级 ， 例 如 (1+2)*3 的 值 为 9。 使 用 括号 也 可 以 增强 代码 的 可 读 性 。 如 果 运 算 符 优先 级 相同 ， 
则 使 用 从 左 到 右 的 左 结合 顺序 左 结 合 表 示 表 达 式 从 左 问 右 求 值 ， 右 结合 相反 )。 

K 2-7 从 高 到 低 列 出 了 PHP 所 有 运算 符 的 优先 级 。 同 一 行 中 的 运算 符 具 有 相同 优先 
级 ， 此 时 它们 的 结合 方 问 决定 求 值 顺序 。 


表 2-7 运算 符 优 先 级 


结合 方向 z 算 符 附加 信息 

dE new 

^r array() 
den pne 递增 / 递减 运算 符 
非 结 合 ! ~ - (int) (float) (string) (array) (object) @ 类 型 

"9 算数 运算 符 
E 算数 运算 符 和 字符 串 运算 符 
^r 位 运算 符 
deem 比较 运算 符 
非 结合 比较 运算 符 

A 位 运算 符 和 引用 
^r 位 运算 符 

^r 位 运算 符 

^r 逻辑 运算 符 
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e 
$ 


方 问 运 SW 附加 信息 


Er 


逻辑 运算 符 
三 元 运算 符 
=+= —= *=/= = þ= &= |= ^= <<= >>= 赋值 运算 符 
and 逻辑 运算 符 
xor 逻辑 运算 符 
or 逻辑 运算 符 
多 处 用 到 
合 前 面 所 用 到 的 操作 符号 来 完成 一 项 需要 综合 使 用 它们 的 任务 ， 如 图 2-21 rz. 
<?php 


/定义 几 个 常量 ， 最 好 是 使 用 大 写 
define(" PEN", 20); /钢笔 为 20 元 
define("RULE",10); /尺子 为 10 元 


$pen_num = 10; /10 只 钢笔 
$ruler num 220; /20 把 尺子 


$total price = $5pen num * PEN 
4 $ruler num * RULE; 


$total price = number. format(Stotal price); 


echo "购买 10 只 钢笔 和 20 把 尺子 一 共 要 人 花 ".$total_price." 元 "; 


A 操作 符 综 合 使 用 - Nicrosoft Internet Explorer 
FP 编辑 人 F) ”查看 0) BEA IAM 帮助 0) 


Qm- O- (i6 Ps zr e e- aBa 
地 址 (D) |Æ] http://127. 0. 0. 1/php/PHP/PHP_use_op. php < 输入 关键 词 搜索 €Ejss sm Q snust E 


define("RULE", 10); /7 尺子 为 10 元 


$pen num = 10; //10H $83 
$ruler num 220; /720 把 尺子 


$total price = $pen num * PEN 
+ $ruler num * RULE; 


$total price = number format ($total price); 


echo “HR 10 H $5840 2018 RF — 3E E15". $total price."J60"; 
Tà 


输出 结果 
购买 10 只 钢笔 和 20 把 尺子 一 共 到 花 400 元 


(AD Internet 


2-01 综合 运算 符 的 应 用 示例 
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| Section 
PHP 的 表达 式 


在 PHP 程序 中 ， 任 何 一 个 可 以 返回 值 的 语句 ， 都 可 以 看 做 表达 式 。 也 束 是 说 ， 表 达 式 
是 一 个 短语 ， 能 够 执行 一 个 动作 ， 并 具有 返回 值 。 一 个 表达 式 通 第 由 两 部 分 构成 ， 一 部 分 是 
操作 数 ， 另 一 部 分 是 运算 符 。 本 贡 介 绍 利用 的 几 种 控制 语句 表达 式 ， 分 别 是 条 件 语 铅 、 循 环 
WAJ, UK require 和 include 语句 等 其 他 语句 。 


2A 


条 件 语句 在 PHP rPdER DR, i6 PHP 程序 的 主要 控制 语句 之 一 。 通 常情 况 下 ， 在 客户 
问 获 得 一 个 参数 ， 根 据 传 入 的 参数 值 ， 做 出 不 同 的 啊 应 。 在 PHP 中 条 件 语 句 分 别 为 让 3E 
AJ, if-else 语句 、if-elseif-else 语句 和 switch 语句 。 

下 面 我 们 分 别 介绍 这 4 种 形式 的 条 件 语句 : 

1. ifi& 4] 

if EAE S mA a PEHEA A, EH 让 语句 可 以 按照 条 件 判断 来 执行 语句 ， 
增强 了 程序 的 可 控制 性 。 只 有 站 语句 的 条 件 语句 是 最 简单 的 一 种 条 件 语句 ， 语 法 如 下 : 


if ( expr ) 


statement 


首先 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement; 如果 值 为 False， 将 忽略 


statement. 


图 2-22 Brzs EXER E SEAT ENT TIGRE EE e 


d 
ST GU | wem E 
False ((&) 


图 2-22 让 语句 逻辑 示意 网 


例如 : 


<?php 
$Num1=10; 
$Num2=9; 
if($Num1>$Num2) 
echo "$Num1 KF $Num2"; 
2» 


上 述 实例 演示 了 f 语句 的 使 用 ， 会 在 变量 $Numl 大 于 $Num2 时 ， 输 出 “$Numl 大 于 
$Num2", 
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2. if-else 语 名 
条 件 语句 的 第 2 种 形式 是 if-else， 除 了 让 语句 之 外 ， 还 加 上 了 else 语句 ， 它 可 以 在 直 话 
人 名 中 的 表达 式 的 值 为 False 时 执行 ， 语 法 如 下 : 


if ( expr ) © 


statement1 
else 
statement2 


首先 ， 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement; 如 果 值 为 False， 则 执 
ÍT statement2。 例 如 ， 人 以 下 代码 在 $a 大 于 $b 时 ， 显 示 a 大 于 b; 有 反之， 则 显示 a 不 大 于 bb。 
这 种 情况 的 执行 逻辑 结构 如 图 2-23 所 示 。 


True ( 真 ) 


A 


False ((B) 
图 2-23 if-else 语句 逻辑 示意 图 


例如 ， 以 下 代码 在 $a 大 于 $b 时 ， 显 示 a 大 于 b; 及 之 ， 则 显示 a 不 大 于 b。 


<?php 
if ($a > $b) 
echo "a 大 于 b"; 
else 


echo "a 不 大 于 b"; 


?> 


注意 : 

else 语句 仅 在 if MA elseif (如 果 有 的 话 ) 语句 中 的 表达 式 的 值 为 False 时 执行 ， 它 不 可 
以 单独 使 用 。 

3. if-elseif-else 语 和 铝 

条 件 语句 的 第 3 种 形式 是 if-elseif-else, elseif 是 让 和 else WHE. M else 一 样 ， 它 延伸 
了 站 语句 ， 可 以 在 原来 的 站 表达 式 值 为 False 时 执行 不 同 语句 。 但 是 和 else 不 一 样 的 是 ， 它 
仅 在 elseif 的 条 件 表达 式 值 为 True 时 执行 语句 ， 语 法 如 下 : 


if ( expl ) 
statementl 


elseif ( exp2 ) 
statement2 
elseif ( exp3 ) 


else 


statementn 
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首先 ， 对 exprl 求 值 ， 如 果 exprl 的 值 为 True， 则 执行 statement1， 如 果 值 为 False， 则 
对 expr2 求 值 , 如 果 expr2 的 值 为 True， 则 执行 statement2; 如 果 值 为 False, Jl] expr3 求 
值 ， 依 次 类 推 ， 如 果 所 有 的 表达 式 的 值 都 为 False， 则 执行 statementn。 

这 种 情况 的 执行 逻辑 结构 如 图 2-24 所 示 。 


图 2-24 if-elseif-else 语句 逻辑 示意 
例如 ， 以 下 代码 将 根据 条 件 分 别 显 示 a 大 于 b，a 等 于 b 和 a 小 于 bb: 


<?php 
if ($a > $b) { 
echo "a 大 于 b"; 
} elseif ($a == $b) { 
echo "a 等 于 b"; 
} else { 
echo "a 小 于 b"; 
} 
2» 
注意 : 
elseif 也 可 以 写成 else if (两 个 单词 )， 它 和 elseif (一 个 单词 ) 的 行为 完全 一 样 。 
4. switch 语 句 
使 用 switch 语句 可 以 避免 大 量 地 使 用 if-else 控制 语句 。switch 语句 首先 根据 变量 值得 到 
一 个 表达 式 的 值 ， 然 后 根据 表达 式 的 值 执行 语句 。switch 语句 计算 expression 的 值 ， 然 后 和 
case 后 的 值 进行 比较 ， 跳 转 到 第 一 个 匹配 的 case 语句 开始 执行 后 面 的 语句 ， 如 果 没 有 case 
匹配 就 跳 转 到 default 语句 执行 ， 如 果 没 有 default 语句 ， 则 退出 。 当 找到 匹配 项 的 时 候 ， 解 
析 器 会 一 直 运 行 ， 直 到 switch 结尾 或 者 遇见 break 语句 为 止 。case 语句 可 以 使 用 空 语句 。 
PHP 提供 了 分 文 (switch) 语句 来 下 接 处 理 多 分 文选 择 ， 语 法 如 下 : 


switch (expr) { 
case constant-expression: 
statement 
jump-statement 
[default: 
statement 
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jump-statement 
] 
j 


其 中 的 常量 表达 式 (constant-expression〉 可 以 是 任何 求 值 为 简单 类 型 的 表达 式 ， 即 整 型 e 
或 浮 点 数 以 及 字符 串 。 
其 逻辑 结构 如 图 2-25 所 示 。 


图 2-25 switch EAJ 4R8 Z5] 


下 面 一 段 代 码 是 switch 语句 的 简单 应 用 : 


<?php 
switch ($a) { 
case 0: 
echo "a = 0"; 
break; 
case 1: 
echo "a = 1"; 
break; 
case 2: 
echo "a = 2"; 
break; 
} 


?> 


switch 语句 一 行 接 一 行 地 执行 《实际 上 是 语句 接 语 句 )。 开 始 时 没有 代码 被 执行 ， 仅 当 
一 个 case 语句 中 的 值 和 switch 表达 式 的 值 上 匹配 时 ，PHP 才 开 始 执行 语句 ， 直 到 switch 的 程 
序 段 结束 或 者 遇 到 第 一 个 break 语句 为 止 。 如 果 不 在 case 的 语句 段 最 后 写 上 break 的 话 ， 
PHP 将 继续 执行 下 一 个 case 中 的 语句 段 。 例 如 : 


<?php 
switch ($a) { 
case 0: 
echo "a = 0"; 
case 1: 
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这 里 如 果 $a 等 于 0, PHP 将 执行 所 有 的 输出 语句 ; 如 果 $a 等 于 1, PHP 将 执行 后 面 两 
条 输出 语句 。 只 有 当 $a 等 于 2 时 ， 才 会 得 到 结果 : a = 2。 


循环 语 名 


循环 语句 也 称 为 从 代 语句 ， 让 程序 香 复 执行 某 个 程序 块 ， 直 到 某 个 特定 的 条 件 表达 式 结 
果 为 假 时 ， 结 束 执行 语句 块 。 在 PHP 中 循环 语句 的 形式 有 : while 循环 、do-while 循环 、for 
循环 和 foreach 循环 。 

1. while 循 环 语句 

while 语句 控制 语句 的 循环 执行 。 格 式 为 : 


while (expr) 
statement 


只 要 expr 的 值 为 True 就 重复 执行 嵌 套 中 的 循环 语句 。 每 次 开始 循环 时 检查 expr 的 
值 。 有 时 如 果 while 表达 式 的 值 一 开始 就 是 False， 则 循环 语句 一 次 都 不 会 执行 。 一 般 来 
说 ， 在 代码 片段 中 会 改变 表达 式 中 变量 的 值 ， 否 则 可 能 成 为 死 循环 。 图 2-26 所 示 为 该 语句 
的 迎 辑 结构 。 


图 2-26 while 语句 逻辑 示意 


例如 : 


<?php 
$a = 1; 
while ($a <= 5) { 
echo $a++; // 从 1~5 依次 输出 
} 
dS 
执行 该 程序 后 会 输出 从 1 一 5 的 数字 。 
2. do-while 循 环 语句 
do-while 语句 和 while 语句 基本 一 样 。 不 同 之 处 在 于 ，while 语句 在 “{}” 内 的 语句 执行 
之 前 检查 条 件 是 否 满足 ， 而 do-while 语句 则 先 执行 “f” 内 的 语句 ， 然 后 再 判断 条 件 是 否 满 
是， 如 末 满 足 就 继续 循环 ， 不 满足 束 跳 出 循环 。 格式 为 
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do 
statement 


while(expr) 


图 2-27 所 示 为 该 语句 的 逻辑 结构 。 


False ( 假 ) 


图 2-27 do-while 语句 逻辑 示意 图 
例如 : 


<?php 
$a = 0; 
do { 
echo $a; 


} 
while ($a > 0); 
2» 


以 上 循环 将 正好 运行 一 次 ， 因 为 经 过 第 一 次 循环 后 ， 当 检 答 表达 陈 的 真 值 时 ， 因 其 值 为 
False ($a 不 大 于 0) mj su EIE. 

3. for 循 环 语句 

for 循环 是 PHP 中 最 复杂 的 循环 结构 。for 循环 的 语法 是 : 


for (expr1; expr2; expr3) 


statement 


其 中 ， 第 1 个 expl 在 循环 开始 前 无 条 件 求 值 一 次 。 第 2 个 expr2 在 每 次 循环 开始 前 求 
值 ， 如 来 值 为 Tre， 则 继续 循环 ， 执 行 租 僚 的 循环 语句 ; 如果 值 为 False， 则 终止 循环 。 第 3 
个 expr3 在 每 次 循环 之 后 被 求 值 〈 执 行 )。 每 个 表达 式 都 可 以 为 衬 。expr2 为 空 意 味 看 将 无 限 
循环 下 去 (和 C 一 样 ，PHP 认为 其 值 为 True)， 因 为 有 时 候 会 希望 用 break 语句 来 结束 循 
环 ， 而 不 是 用 for 的 表达 式 真 值 判断 。 

图 2-28 所 示 为 该 语句 的 逻辑 结构 ， 表 达 式 2 为 True 则 执行 程序 片段 ， 其 值 在 表达 式 1 
中 初始 化 ， 在 表达 式 3 中 进行 修改 。 


False (fB) 
图 2-28 for 语句 逻辑 示意 网 
下 面 通过 使 用 for 循环 语句 输出 九 九 乘法 表 : 


<?php 
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for($i=1;$i<10;$i++) 
{ 
for($j=1;$j<10;$j++) 
{ 
echo "$i*+$j=".$i*$j; 
echo "&nbsp"; 
j 


echo "<br/>"; 


j 
2» 
4. foreach 循 环 语句 
foreach 语句 是 一 种 用 来 过 历数 组 中 数据 的 简便 方法 。foreach 仪 能 用 于 数组 ， 当 试图 将 
其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。foreach 语句 有 两 种 语法 ， 第 2 
种 比较 次 要 ， 但 却 是 第 1 种 的 有 用 的 扩展 。 
第 1 种 语法 : 
foreach (array_expression as $value) 


statement 
第 2 种 语法 : 


foreach (array_expression as $key => $value) 


statement 


第 1 种 语法 格式 过 历 给 定 的 array expression 数组 。 每 次 循环 中 ， 当 前 单元 的 值 被 赋 给 
$value， 并 且 数 组 内 部 的 指针 问 前 移 一 步 〈 因 此 下 一 次 循环 中 将 会 得 到 下 一 个 单元 )。 第 2 种 
格式 做 同样 的 事 ， 只 除了 当前 蛙 元 的 键 名 也 会 在 每 次 循环 中 被 赋 给 变量 $key. HAIT BJ 
辑 结构 如 图 2-29 所 示 。 


False ( 假 ) 


图 2-29 foreach 语句 逻辑 示意 图 


该 语句 的 使 用 方法 如 下 : 


<?php 
$arr = array("one", "two", "three"); 
foreach ($arr as $value) { 
echo "Value: $value<br />\n"; 


j 


?> 


WEBERA AN : 
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Value: one 


Value: two 
Value: three 


在 这 段 代 码 中 遍历 数组 使 用 的 是 foreach 语句 的 第 1 种 格式 ， 也 可 以 使 用 第 2 种 格式 。 O) 
改写 上 面 的 代码 如 下 : 


<?php 
$arr = array("one", "two", "three"); 


foreach ($arr as $key => $value) { 
echo "Key: $key; Value: $value<br />\n"; 
}2> 


此 段 代码 的 输出 为 : 


Key: 0; Value: one 
Key: 1; Value: two 
Key: 2; Value: three 


其 他 语句 
为 了 帮助 程序 员 更 加 精确 地 控制 整个 流程 ， 方 便 程序 的 设计 ，PHP 还 提供 了 一 些 其 他 语 
人 句 ， 这 里 做 一 下 简单 的 介绍 。 

(1) break 语句 。break 语句 用 来 结束 当前 的 for. while 或 switch 循环 结构 ， 继 续 执 行 下 
面 的 语句 。break 语句 后 面 可 以 跟 一 个 数学 ， 用 于 在 散人 套 的 控制 结构 中 表示 跳出 控制 结构 的 

(2) continue 语句 。continue 语句 用 来 跳出 循环 体 ， 不 继续 执行 循环 体 下 耐 的 语句 ， 而 
是 回 到 循环 判断 表达 式 ， 并 决定 是 否 继续 执行 循环 体 。continue 语句 后 面 同样 可 以 跟 一 个 数 
字 ， 其 作用 和 break 语句 相同 。 

(3) return 语句 。return0) 语 句 通常 用 于 函数 中 ， 如 果 在 一 个 函数 中 调用 retumO i88), X4 
立即 结束 此 水 数 的 执行 并 将 它 的 参数 作为 函数 的 值 返 回 。 

(4) includeO 语 名 和 requireO 语 句 。 包 含 并 运行 指定 文件 。require0 和 includeO 除 了 处 理 
失败 之 外 ， 在 其 他 方面 都 完全 一 样 。include0 产 生 一 个 警告 ， 而 require0 则 导致 一 个 致命 错 
误 。 也 就 是 说 ， 如 果 想 在 丢失 文件 时 停止 处 理 页 面 ， 应 该 使 用 require0， 而 includeO0 则 会 继 
续 执 行 脚本 ， 同 时 也 要 确认 设置 了 合适 的 include path. 

(5) require once()i Jl include_once) f]. require once i5 5]4l include_onceO 语 句 分 
别 对 应 requireO 语 句 和 includeO 语 句 。require_once0 语 句 和 include onceQ18 4] EAH T vi 
包含 多 个 文件 时 ， 可 以 有 效 地 避免 把 同一 段 代 但 包含 进去 而 出 现 函 数 或 变量 重复 定义 的 错 


IRo 
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PHP 的 函数 


程序 在 完成 一 个 功能 时 ， 可 以 把 众多 的 程序 写 在 一 起 ， 但 这 样 容 易 引 起 混乱 。 为 一 种 策 
略 加 是 把 总 的 功能 分 成 小 的 功能 异世 ， 把 每 一 个 模块 分 别 实 现 ， 在 总 的 框 杂 中 根据 需要 把 模 
块 搭建 在 一 起 。 实 现 程 序 模块 化 的 全 略 束 是 使 用 函数 ， 和 直观 来 说 ， 函 数 束 是 代表 一 组 语句 的 
标识 从， 在 使 用 函数 时 ， 外 部 调用 者 不 需要 关心 函数 的 内 部 处 理 过 程 ， 只 需要 关心 函数 的 输 
入 和 输出 接口 的 应 用 。 函 数 可 以 人 刹 单 地 分 为 两 大 类 : 一 类 是 系统 函数 ， 一 类 是 用 户 目 定义 隙 
数 。 对 于 系统 函数 ， 可 以 在 需要 时 下 接 选 择 使 用 ， 而 用 户 目 定义 函数 ， 痛 先 要 定义 ， 然 后 才 
能 使 用 。 本 节 的 重点 是 如 何 定义 并 使 用 用 户 目 定义 函数 ， 主 要 包括 函数 定义 的 一 般 形 式 、 函 
数 的 参数 和 返回 值 、 函 数 的 租 套 和 地 归 等 。 


ETUE 使 用 函数 


一 个 函数 可 由 以 下 的 语法 来 定义 : 


function funcName([$arg_1][, $arg_2][，…][, $arg npf 
statement 


j 


定义 函数 是 需要 使 用 function KEF, LL Jn xe ERU. BAI RAA AL LRE A 
线 打 头 ， 后 面 跟 字母 、 数 字 或 下 画 线 。$arg_1 füSarg n 为 函数 的 可 选 参数 列表 ， 不 同 的 参数 
之 间 用 喜 号 分 隔 。 在 函数 内 部 可 以 放置 任何 有 效 的 PHP 代 人 但， 甚 全 包括 其 他 函数 和 凑 定 
义 。 

例如 : 


<?php 

function maxNum($a,$b){ 
$c-$a»$b?$a:$b; 

return $c; 

} 

echo maxNum(10,100); // 输出 : 100 


上 和 面 的 一 段 代 人 码 也 可 以 写成 : 


<?php 

echo maxNum(10,100); // 输出 : 100 
function maxNum($a,$b){ 
$c-$a»$b?$a:$b; 

return $c; 


j 


?> 
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设置 函数 参数 | 


通过 函数 参数 列表 可 以 传递 信息 到 函数 。PHP 支持 按 值 传递 参数 ， 通 过 引用 传递 以 及 默 
认 参 数 。 默 认 情况 下 ， 冰 数 参数 通过 值 传递 ， 即 若 在 函数 内 部 改变 了 参数 的 值 ， 也 不 会 影响 
到 函数 外 部 的 值 。 

例如 : 


<?php 

function change($string){ 
$string = "改变 之 后 "; 

} 

$str = "ELA"; 

change($str); 


echo $str; 
Is 


这 段 代码 的 输出 为 “改变 之 前 ”。 尽 管 在 国 数 内 部 改变 了 参数 $string KIE, iA 
到 函数 外 部 $str 的 值 。 如 采 布 望 允许 函数 修改 它 的 参数 值 ， 必 须 通 过 引用 传递 参数 ， 方 法 是 
在 函数 定义 中 该 参数 的 前 面 预 先 加 上 “ 信 ” 符 号 。 

修改 上 面 的 代码 如 下 : 


<?php 

function change(&$string){ 
$string = "& AÈ Z Jn"; 

} 

$str= 改变 之 六 

change(Sstr); 

echo $str; 

jo: 


这 段 代 人 码 的 输出 为 “改变 之 后 ”。 在 函数 内 部 改变 了 参数 $string 的 值 ， 也 影响 到 了 函数 
外 部 $str 的 值 。 前 后 两 段 代 但 的 唯一 区 列 融 是 ， 后 面 一 段 代 但 的 参数 传递 是 引用 传递 ， 即 在 
因数 定义 中 的 参数 前 面 加 上 了 “人 ”符号 。 


2.83 y [n] E ALB | 


所 有 的 函数 都 可 以 有 返回 值 ， 也 可 以 没有 返回 值 ， 主 要 是 通过 使 用 可 选 的 return 18.4] 
返回 值 。 任 何 类 型 都 可 以 返回 ， 其 中 包括 列表 和 对 象 。 这 导致 图 数 立即 结束 运行 ， 并 且 将 控 
制 权 传递 回 被 调用 的 行 。 

举例 如 下 : 


<?php 
$num1=100; 


er 


f PHP+ 


$num2-2200; 
echo "最 大 的 是 ".maxNum($num1, $num2); / 输出 : 最 大 的 是 200 
function maxNum($a,$b){ 
if($a<$b) $a = $b; 
return $a; 


j 


?> 


eK A B Fa 


PHP IM Zi n UREE XAH. PIIBHCROE Xo WÜUETEXEOL 7 BRAAUNE, H 


HARARE. AAN RI ERU BE CE Q5 E HE ERU URL 8. E 


效 ， niis 


<?php 
function foo() 
{ 
function bar() 
{ 
echo "并 没有 关闭 直到 foo0 函 数 被 应 用 ."; 
j 
j 
F* ANBEBCEIVHR] baroke DAE JPRCH ABO BI. 对 
foo(); 
ILAE nT EAE HR] baror ži, 
fooO's 的 进程 允许 使 用 . */ 
bar(); 
2» 


这 段 代 码 的 输出 为 “并 没有 关 财 、 直 到 foo0 函 数 被 应 用 。”。 


所 请 垦 套 调用 ， 束 是 在 调用 一 个 函数 的 过 程 中 ， 又 调用 为 一 个 函数 。 举 例如 下 : 


<?php 

$num1=100; 

$num2=200; 

myoutput($num1, $num2); 

function myoutput($a, $b){ 

echo "最 大 的 是 ".maxNum($a, $b); 
} 

function maxNum($a,$b)( 

if($a<$b) $a = $b; 

return $a; 


j 


?> 


这 段 代 人 码 的 输出 是 “最 大 的 是 200”. fEJG BLEUS F AHA myoutput0， 而 在 调用 这 
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个 函数 的 过 程 中 ， 又 调用 了 另 一 个 函数 maxNumO,. AE RA RC UR] H] 
PHP 中 还 允许 函数 的 递归 调用 ， 即 在 调用 一 个 函数 的 过 程 中 又 直接 或 则 接地 调用 该 函数 
本 喘 。 举 例如 下 : 


<?php © 


recursion(5); 
function recursion($a) 
{ 
if ($a <= 10) { 
echo "$a "; 
recursion($a + 1); 
} 
} 


?> 
这 段 代 码 的 输出 是 数字 5，6，7，8，9，10。 在 此 段 代 码 中 首先 调用 的 recursion, m 
在 调用 这 个 函数 的 过 程 中 ， 如 果 参 数 的 值 小 于 等 于 10， 则 又 调用 此 函数 本 有 身 ， 这 残 是 函数 的 
递归 调用 。 秽 套 和 递归 的 应 用 在 使 用 PHP 进行 一 些 结算 系统 的 应 用 时 经 常 使 用 到 ， 需 要 读 
者 举一反三 ， 清 晰 地 掌握 逻辑 关系 后 才 可 以 进行 应 用 ， 否 则 经 和 常 容易 出 现 死 循环 。 
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PHP 和 MySQL 数 据 库 的 操作 


要 想 快 速成 为 PHP 网 页 编程 蜗 手 ， 核 心 掌 握 PHP 和 MySQL 的 数据 库 操作 是 非常 重要 
的 。 一 般 PHP 实现 对 MySQL. 的 操作 主要 包括 连接 、 创 建 、 搬 入、 选择、 查询、 排序、 更 狐 
以 及 删除 等 操作 。 下 和 面 就 分 别 介 绍 一 下 实现 这 些 功 能 的 函数 命令 。 


| 连接 数据 库 mysq|l_connect() 


在 能 够 访问 并 处 理 数 据 库 中 的 数据 之 前 ， 必 须 创 建 到 达 数 据 库 的 连接 。 在 PHP P, X 
个 任务 通过 mysql_connect) K Zi o8 p. 

语法 : mysql connect(servername,username, password) 

举例 如 下 。 

在 下 面 的 例子 中 ， 在 一 个 变量 中 ($conn) 存放 了 在 脚本 中 供 稍 后 使 用 的 连接 。 如 果 连 接 


失败 ， 将 执行 die 部 分 。 


<?php 
$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 

{ 

die(' 不 能 连接 数据 库 : . mysql. error); 

} 


TS 
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脚本 一 结束 ， 了 驶 会 关闭 连接 。 如 需 提 前 关 团 连接 ， 使 用 mysql_close() 函数 实现 。 


<?php 


$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 
{ 
die(' 不 能 连接 数据 库 : '. mysql_error); 
} 
mysql_close($conn); 
1> 


o P 


创建 数据 库 CREATE 


CREATE DATABASE 语句 用 于 在 MySQL 中 创建 数据 库 。 

语法 : CREATE DATABASE database name 

为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql_query) PR. RAAHE MySQL 
XE pec ys tM ptg e 

举例 如 下 。 

在 下 面 的 例子 中 ， 创 建 了 一 个 名 为 my. db 的 数据 库 : 


<?php 
$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 
{ 
die(' 不 能 连接 数据 库 : '. mysql. errorQ); 
} 
if (mysql query "CREATE DATABASE my_db",$conn)) 
{ 
echo "Database created"; 
} 
else 
{ 
echo "Error creating database: " . mysql. error(); 
} 
mysql close($conn); 
2» 


CREATE TABLE 用 于 在 MySQL 中 创建 数据 库 表 。 
语法 : 


CREATE TABLE table name 
( 

column namel data type, 
column name2 data type, 
column name3 data type, 
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为 了 执行 此 命令 ， 必 须 问 mysql_query() PAIS] CREATE TABLE 语句 。 


举例 如 下 。 c 
下 例 展示 了 如 何 创建 一 个 名 为 Persons 的 表 。 此 表 有 3 列 ， 列 名 是 FirstName, 
LastName 以 及 Age: 


<?php 
$conn = mysql_connect("localhost 
if (!I$conn) 
{ 
die(' 不 能 连接 数据 库 :' mysql_error0); 
j 
if (mysql. query "CREATE DATABASE my. db",$conn)) 
{ 


echo "Database created"; 


} 
else 
{ 
echo "Error creating database: " . mysql_error(); 
} 
mysql select db("my. db", $conn); 
$sql = "CREATE TABLE Persons 
( 
FirstName varchar(15), 
LastName varchar(15), 
Age int 
) "n : 
mysql. query($sql,$conn); 
mysql close($conn); 
2» 


在 创建 表 之 前 ， 首 先 必须 选择 数据 库 。 通 过 mysql select dbO. AZOA ŽE EE. CA BUSE 
varchar 类 型 的 数据 库 字 段 时 ， 必 须 规 定 该 字段 的 最 大 长 度 ， 例 如 varchar(15)。MySQL 各 种 
数据 类 型 表 如 表 2-8 一 表 2-11 所 示 。 


"o "on 


, root"," admin"); 


表 2-8 MySQL 数据 类 型 表 


数值 类 型 Hx 
int(size) 
smallint(size) 仅 支持 整数 
eie) | 在 size 参数 中 规定 数字 的 最 大 值 
bigint(size) 


decimal(size,d) | — 支持 带 有 小 数 的 数字 


pure 在 size 参数 中 规定 数字 的 最 大 值 。 在 d 参数 中 规定 小 数 点 右 侧 的 数字 的 最 大 值 
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表 2-9 文本 数据 类 型 表 


文本 数据 类 型 jü 述 
文 持 固 定 长 度 的 字符 串 。【〈 可 包含 字母 、 数 字 以 及 特殊 符号 ) 


har(si E e 
ue 在 size 参数 中 规定 固定 长 度 
etes 支持 可 变 长 度 的 字符 串 〈( 可 包含 字母 、 数 字 以 及 特殊 符号 ) 
在 size 参数 中 规定 最 大 长 度 
tinytext 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 255 个 字符 
TM 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 65535 个 字符 
mediumtext EE Poe 
süedhusmblob SCEEHTAEHEBEBUAE REB. EAK 16777215 个 字符 
l Z. È Iu AA 三 | pa Du y 
eee 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 4294967295 个 字符 
表 2-10 日 期 数据 类 型 表 
日 期 数据 类 型 jJ ” R 
date(yyyy-mm-dd) 
datetime(yyyy-mm-dd hh:mm:ss) 支持 日 期 或 时 间 


timestamp(yyyymmddhhmmss) 
time(hh:mm:ss) 


R 2-11 杂项 数据 类 型 表 


杂项 数据 类 型 ji 述 
enum(valuel ,value2,ect) enum 是 enumerated 列表 的 缩写 。 可 以 在 括号 中 存放 最 多 65535 ME 
set set 与 enum 相似 。 但 是 ，set 可 拥有 最 多 64 个 列表 项 目 ， 并 可 存放 不 止 一 个 choice 


每 个 表 都 应 有 一 个 主键 字段 。 主 键 用 于 对 表 中 的 行进 行 唯 一 标识 ， 每 个 主键 值 在 表 中 必 
须 是 唯一 的 。 此 外 ， 主 键 字段 不 能 为 空 ， 这 是 由 于 数据 库 引 擎 需要 一 个 值 来 对 记录 进行 定 
位 。 主 键 和 字段 永 远 要 被 编 入 索引 ， 这 条 规则 没有 例外 ， 必 须 对 主键 字段 进行 索引 ， 这 样 数 据 
库 引 擎 才能 快速 定位 给 予 该 键 值 的 行 。 

下 面 的 例子 把 personID 字段 设置 为 主键 字段 。 主 键 字 段 通 单 是 ID 写 ， 且 通常 使 用 
AUTO INCREMENT 设置 。AUTO_INCREMENT 会 在 新 纪录 被 添加 时 逐一 增加 该 字段 的 
值 。 要 确保 主键 字段 不 为 宇 ， 必 须 同 该 字段 添加 NOT NULL XH. 
举例 如 下 。 


$sql = "CREATE TABLE Persons 

( 

personID int NOT NULL AUTO INCREMENT, 
PRIMARY KEY (personID), 

FirstName varchar(15), 

LastName varchar(15), 

Age int 

)5 

mysql query($sql,$Sconn); 
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插入 数据 INSERT INTO 


INSERT INTO 语句 用 于 同 数 据 库 表 洪 加 新 记录 。 © 
语法 : 


INSERT INTO table name 
VALUES (valuel, value2,::-) 


还 可 以 规定 希望 在 其 中 插入 数据 的 列 : 


INSERT INTO table name (columnl, column2,::: 
VALUES (valuel, value2,::-) 


SQL 语句 对 大 小 写 不 敏感 。 INSERT INTO 与 insert into 相同 。 为 了 让 PHP 执行 该 语 
AJ, WEH mysql_query) 函数 。 该 函数 用 于 癌 MySQL. 连接 发 送 得 询 或 命令 。 

举例 如 下 。 

在 前 面 创建 了 一 个 名 为 Persons 的 表 ， 有 3 列 : Firstname, Lastname 以 及 Age. HEF 
例 中 使 用 同样 的 表 。 下 面 的 例子 癌 Persons KDT 2 个 新 记录 : 


<?php 
$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 
{ 
die( 不 能 连接 数据 库 :". mysql. errorO); 
} 
mysql select db("my. db", $conn); 
mysql query("INSERT INTO Persons (FirstName, LastName, Age) 
VALUES (chen', 'yicai', 35"); 
mysql query("INSERT INTO Persons (FirstName, LastName, Age) 
VALUES (yu, 'heyun', '28)"); 
mysql. close($conn); 


?> 
选取 数据 SELECT 
SELECT 语句 用 于 从 数据 库 中 选取 数据 。 
语法 : 


SELECT column name(s) FROM table name 


SQL 语句 对 大 小 写 不 pos IX, SELECT 与 select 等 效 。 为 了 让 PHP 执行 上 面 的 语句 ， 必 须 
使 用 mysql queryO. 函数 。 — MySQL AX AWS « 

举例 如 下 。 

下 面 的 例子 选取 存储 在 Persons 表 中 的 所 有 数据 CS. 字符 选取 表 中 所 有 数据 ): 


上 和 面 这 个 例子 在 $result 变量 中 存放 由 mysql queryO 


vA 


HP+IV 
<?php 

$conn = mysql_connect("localhost","root","admin"); 

if (!$conn) 


{ 
die(' 不 能 连接 数据 库 :'. mysql_error()); 
} 
mysql select db("my. db", $conn); 
$result = mysql query( SELECT * FROM Persons"); 
while($row = mysql. fetch, array(S$result)) 
{ 
echo Srow[ FirstName'] . " " . Srow['LastName']; 
echo "<br /»"; 
} 
mysql close($conn); 
2» 
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函数 返回 的 数据 。 接 下 来 ， 使 用 


mysql_fetch_arrayO 国 数 以 数组 的 形式 从 记录 集 返 回 第 1 行 。 随 后 对 mysql_fetch_array() P 
数 的 每 次 调用 都 会 返回 记录 集中 的 下 一 行 。while loop 语句 会 循环 记录 集中 的 所 有 记录 。 为 
了 输出 每 行 的 值 ， 使 用 了 PHP 的 $row 变量 ($row['FirstName'] 和 $row['LastName'])。 


条 件 查询 WHERE 


如 需 


选取 匹配 指定 条 件 的 数据 ， 请 向 SELECT 语句 添加 WHERE 子 句 。 
语法 : 


SELECT column FROM table 
WHERE column operator value 


下 和 面 如 表 2-12 所 示 的 运算 符 可 与 WHERE 子 句 一 起 使 用 。 


SQL 


R 2-12 可 用 于 碍 询 的 运算 符 


运 算 mW 说 明 
= 等 于 
I= 不 等 于 
> NF 
< 小 于 
>= 大 于 或 等 于 
<= 小 于 或 等 于 
BETWEEN 介 于 一 个 包含 范围 内 
LIKE 搜索 匹配 的 模式 


语句 对 大 小 与 不 a WHERE 与 where 等 效 。 为 了 让 PHP 执行 上 面 的 语句 ， 必 
须 使 用 mysql. queryOrRZi.. iAPRUH T IRI. SQL 连接 发 这 会 询 和 命令 。 
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举例 如 下 。 
下 面 的 例子 将 从 Persons 表 中 选取 所 有 FirstName-'Root' 的 行 : 


<?php | 
$conn = mysql connect("localhost", "root", "admin"); c 
if (!$conn) | 

{ 

die(' 不 能 连接 数据 库 : '. mysql_error); 

} 
mysql select db("my. db", $conn); 
$result = mysql query( SELECT * FROM Persons 
WHERE FirstName- chen"); 


while($row = mysql. fetch, array($result)) 
{ 
echo $row[ FirstName'] . 
echo "<br >"; 


j 


2» 


"on 


. $row['LastName']; 


数据 排序 ORDER BY ) 


ORDER BY 关键 词 用 于 对 记录 集中 的 数据 进行 排序 。 
语法 : 


SELECT column name(s) 
FROM table name 
ORDER BY column name 


SQL 对 大 小 写 不 敏感 ，ORDER BY 5 order by 等 效 。 
举例 如 下 。 
下 面 的 例子 选取 persons 表 中 存储 的 所 有 数据 ， 并 根据 Age 列 对 结果 进行 排序 


<?php 
$conn = mysql_connect("localhost 
if (!$conn) 

{ 

die(' 不 能 连接 数据 库 :'. mysql_error()); 

} 
mysql select db("my. db", $conn); 
$result = mysql. query( SELECT * FROM Persons ORDER BY Age"); 
while($row = mysql. fetch, array($result)) 

{ 


echo Srow[ FirstName']; 


"o "on 


, root"," admin"); 


"on 


echo " " . $row['LastName']; 
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echo " " . $row['Age']; 
echo "<br />": 


j 
mysql close($conn); 
jo. 


如 果 使 用 ORDER BY 关键 词 ， 记 录 集 的 排序 顺序 默认 是 升序 (1 在 9 之 前 a 在 p 之 
前 )。 使 用 DESC 关键 词 来 设 定 降序 排序 (9 在 1 之 前 , p 在 a 之 前 ): 


SELECT column name(s) 
FROM table name 
ORDER BY column name DESC 


可 以 根据 两 列 进行 排序 ， 也 可 以 根据 多 个 列 进行 排序 。 当 按照 多 个 列 进行 排序 时 ， 只 有 
第 1 列 相同 时 才 使 用 第 2 列 : 


SELECT column name(s) 
FROM table name 
ORDER BY column namel, column name2 


更 新 数据 UPDATE 


UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 。 
语法 : 
UPDATE table name 


SET column name = new. value 


WHERE column name = some value 


SQL 对 大 小 与 不 敏感 ，UPDATE 与 update 等 效 。 为 了 让 PHP HÁT EMEA, qeu 
用 mysql_gquery0 函 数 。 该 函数 用 于 癌 SQL 连接 发 送 查 询 和 命令 。 

举例 如 下 。 

下 向 的 例子 更 狐 Persons 表 的 一 些 数据 : 


<?php 
$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 

{ 

die(' 不 能 连接 数据 库 :'. mysql. errorQ); 

} 
mysql select db("my. db", $conn); 
mysql query("UPDATE Persons SET Age = '38' 
WHERE FirstName = 'chen' AND LastName = 'yicai'"); 
mysql close($conn); 
1> 
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2 删除 数据 DELETE FROM 


DELETE FROM 语句 用 于 从 数据 库 表 中 删除 记录 。 >D 
语法 : 


DELETE FROM table name 
WHERE column name = some value 


SQL 对 大 小 写 不 敏感 ，DELETE ; FROM 与 delete from 等 效 。 为 了 让 PHP 执行 上 面 的 语 
人 句 ， 必 须 使 用 mysql. query( ) 函 数 。 访 函数 用 于 同 SQL 连接 发 送 在 询 和 命令 。 
举例 如 下 。 


<?php 
$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 
{ 
die(' 不 能 连接 数据 库 : . mysql. error); 
} 
mysql_select_db("my_db", $conn); 
mysql query("DELETE FROM Persons WHERE LastName-'yicai'"); 
mysql close($conn); 
s 


本 小 市 介绍 了 PHP 实现 MySQL 数据 库 的 一 些 常 用 操作 ， 读 者 在 学 习 的 时 候 一 定 要 认真 
编写 每 一 行 的 代码 ， 养 成 民 好 的 规范 ， 方 便 今 后 的 提高 学 习 。 
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对 于 初学 者 而 言 ， 学 习 PHP 入 门 最 好 的 方法 就 是 使 用 Dreamweaver 配合 MySQL 进行 动态 系 
统 的 开 有 发。 之 所 以 说 它 是 最 好 的 方法 是 因为 可 以 用 Dreamweaver. 内 置 的 服务 器 行为 天 联 起 来 。 
Dreamweaver 提供 了 方便 的 网 形 化 界面 ， 只 需 使 用 鼠标 选择 ， 输 入 一 些 基 本 设置 参数 束 能 够 与 
MySQL 数据 库 交 互 ， 实 现 建立 数据 、 得 询 记 录 、 痢 增 记 录 、 更 新 记录 、 删 除 记 录 等 操作 ， 人 简单 地 
说 ， 不 用 目 己 写 程 序 即 可 以 实现 Dreamweaver+MYySQL 动态 系统 的 开发 。 本 章 将 介绍 如 何 使 用 这 
些 服务 右 行 为 ， 引 导 大 家 去 阅读 由 Dreamweaver 所 产生 的 程序 代码 ， 了 解 Dreamweaver 的 程序 远 
辑 ， 同 时 掌握 PHP 动态 网 页 开发 的 基础 和 一 些 重 要 的 概念 。 


sa MA ATJE) EIU 
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© 掌握 Dreamweaver 进行 PHP 开发 的 流程 
(7 搭建 PHP 动态 系统 开发 的 平台 

(— 检查 数据 库 记 录 的 常见 操作 

O 编辑 记录 的 常见 操作 
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Dreamweaver 动 太 网 页 制作 步 又 


使 用 Dreamweaver 中 的 服务 器 行为 可 以 快速 实现 PHP, ASP 以 及 JSP 等 动态 网 站 
的 功能 开发 。 对 于 初学 者 而 言 不 用 掌握 相关 的 程序 编写， 只 需要 掌握 一 定 的 操作 顺 
序 ， 了 解 相 关 的 服务 器 行为 即 可 以 轻松 实现 动态 网 站 的 建设 。 设 计 使 用 Dreamweaver 
成 功 进行 PHP 动态 网 页 的 制作 并 创建 一 个 动态 Web 站 点 ， 可 以 用 如 下 几 个 关键 步骤 来 
X11 « 

第 一 步 : 设计 静态 PHP 页 面 

在 设计 任何 Web 站 点 (无 论 是 静态 的 还 是 动态 的 ) 时 的 一 个 关键 步骤 是 页 面 视 觉 效 果 
的 设计 。 当 癌 网 页 中 添 加 动态 元 妹 时 ， 页 面 的 设计 对 于 其 可 用 性 至 关 重 要 。 要 仔细 考虑 用 户 
将 如 何 与 各 个 页 面 和 整个 Web 站 点 进行 交互 。 

将 动态 内 容 合 并 到 网 页 的 常用 方法 是 创建 一 个 显示 内 容 的 表格 ， 然 后 将 动态 内 容 导 
该 表格 的 一 个 或 多 个 单元 格 中 。 利 用 此 方法 ， 可 以 用 一 种 结构 化 的 格式 来 表示 各 种 类 型 的 
Hio 

第 二 步 : 创建 动态 内 容 源 

动态 Web 站 点 需要 一 个 内 容 源 ， 在 将 数据 显示 在 网 页 上 之 前 ， 动 态 Web 站 点 需要 从 该 
内 容 源 提取 这 些 数 据 。 能 在 网 页 中 使 用 内 容 源 之 前 ， 必 须 执 行 以 下 操作 。 

(1) 创建 动态 内 容 源 (如 数据 库 ) 与 处 理 该 页 面 的 应 用 程序 服务 器 之 间 的 连接 。 使 用 
“ 绑 定 ”面板 创建 数据 源 ， 然 后 可 以 选择 数据 源 并 将 其 插入 到 页 和 面 中 。 

(2) 通过 创建 记录 集 ， 指 定 要 显示 的 数据 库 中 的 信息 ， 或 指定 希望 在 该 页 面 中 包括 的 变 
量 。 还 可 以 在 记录 集 对 话 框 内 测试 查询， 并 可 以 进行 任何 必要 的 调整 ， 然 后 再 将 其 添加 到 
“ 绑 定 ”和 面板 。 

(3) 选择 动态 内 容 元 条 并 将 其 插入 到 选 定 页 向 。 

第 三 步 : 向 网 页 添加 动态 内 容 

定义 记录 集 或 其 他 数据 源 并 将 其 添加 到 “ 绑 定 ”面板 后 ， 可 以 将 该 记录 集 所 代表 的 动态 
内 容 插入 到 页 面 中 。Dreamweaver 的 沫 单 张 动 型 界面 使 得 添加 动态 内 容 元 素 非常 和 测 单 ， 只 需 
从 “ 绑 定 ”面板 中 选择 动态 内 容 源 ， 然 后 将 其 插入 到 当前 页 面 内 的 相应 文本 、 网 像 或 表单 对 
象 中 即 可 。 

将 动态 内 容 元 素 或 其 他 服务 器 行为 插入 到 页 面 中 时 ，Dreamweaver 会 将 一 段 服务 需 冰 脚 
本 插入 到 该 页 面 的 源 代 码 中 。 访 脚本 指示 服务 堪 从 定义 的 数据 源 中 检索 数据 ， 然 后 将 数据 呈 
现在 该 网 页 中 。 奉 要 在 网 页 中 放置 动态 内 容 ， 请 执行 以 下 操作 之 一 。 

(D 将 其 放 在 “代码 ”视图 或 “设计 ”视图 中 的 插入 点 处 。 

(2) 蕉 换文 本 字符 串 或 其 他 占 位 符 。 

(3) 将 其 插入 到 HTML 属性 中 。 例 如 ， 动 态 内 容 可 以 定义 图 像 的 src 属性 或 表单 域 的 
value 属性 。 

第 四 步 : 向 页 面 添加 服务 器 行为 

除了 添加 动态 内 容 外 ， 还 可 以 通过 使 用 服务 器 行为 将 复杂 的 应 用 程序 逻辑 结合 到 网 


yz 
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Ho REITA x TUE XH Sn a Fr Ex, AXE [8] Pd XLZSABPSEHT RE F3ESR. Maus 
供 更 强 的 交互 性 能 和 功能 。 

Dreamweaver 服务 堪 行 为 可 以 问 Web. x ESSA HIER YEAR. TAA ESI. 
B6 Dreamweaver 提供 的 服务 器 行为 支持 ColdFusion. ASP 和 PHP 文档 类 型 。 服 务 器 行为 经 
过 精心 编写 和 仔细 测试 ， 达 到 快速 、 安 全 和 可 菲 的 目的 。 内 置 服务 上 右 行 为 文 持 跨 平台 网 页 ， 
x& HT PUR D Vds e 

Dreamweaver 提供 指 癌 并 单 击 (pointrand-click) 界 面 ， 这 种 界面 使 得 将 动态 内 容 和 
复杂 行为 应 用 到 页 面 瓯 像 插 入 文本 元 素 和 设计 元 素 一 样 答 单 。 可 使 用 的 服务 器 行为 如 
下 上 所 述 。 

(OD 定义 来 目 现 有 数据 库 的 记录 集 。 所 定义 的 记录 集 随 后 存储 在 “ 绑 定 ”面板 中 。 

(2) 在 一 个 页 面 上 显示 多 条 记录 。 可 以 选择 整个 表 、 包 含 动 态 内 容 的 各 个 单元 格 或 各 
行 ， 并 指定 要 在 每 个 页 面 视图 中 显示 的 记录 数 。 

(3) 创建 动态 表 并 将 其 插入 到 页 面 中 ， 然 后 将 该 表 与 记录 集 相 关联 。 以 后 可 以 分 别 使 用 
属性 检 得 器 和 重复 区 域 服务 器 行为 来 修改 表 的 外 观 和 重复 区 域 。 

(4) 在 页 面 中 插入 动态 文本 对 象 。 插 入 的 文本 对 象 是 来 目 预定 义 记 录 集 的 项 ， 可 以 对 其 
应 用 任何 数据 格式 。 

(5) 创建 记录 导航 和 状态 控件 、 主 /详细 页 面 以 及 用 于 更 新 数据 库 中 信息 的 表单 。 

(6) 显示 来 自 数据 库 记 录 的 多 条 记录 。 

CD 创建 记录 集 导 航 链 接 ， 这 种 链接 允许 用 户 查 看 来 日 数据 库 记 录 的 前 和 面 或 后 面 的 记录 。 

(8) 添加 记录 计数 器 ， 以 帮助 用 户 跟 踩 返 回 的 记录 数 以 及 其 在 返回 结果 中 所 处 的 
位 置 。 

(9) 还 可 以 通过 编写 目 己 的 服务 堪 行 为 或 者 安 钱 由 第 三 方 编写 的 服务 器 行为 来 扩展 
Dreamweaver 服务 器 行为 。 

第 五 步 : 测试 和 调试 页 面 

在 将 动态 页 或 整个 Web 站 点 发 布 到 Web 上 之 有 前， 应 首先 测试 其 功能 。 通 过 测试 可 以 检 
得 程序 开发 的 结果 ， 如 果 出 现 错误 要 及 时 进行 更 改 。 


搭建 PHP 动 态 系统 平台 


ERHI PHP 动态 网 页 开发 其 实 很 简单 ， 本 章 融 以 实例 的 形式 具体 介绍 Dreamweaver 中 
服务 器 行为 的 使 用 方法 。 在 开始 制作 一 个 PHP 网 站 之 表 ， 需 要 在 Dreamweaver 中 定义 一 个 
狐 网 站 。 在 “新 建站 点 ”中 可 以 让 Dreamweaver 知道 现在 的 网 站 本 地 目录 及 测试 的 路 径 等 信 
县 ， 另 外 一 项 工作 就 是 数据 库 的 创建 工作 。 


系统 结构 设计 


“PHP 动态 功能 ”的 系统 结构 设计 如 图 3-1 所 示 。 本 系统 主要 的 结构 分 成 用 户 登 录入 口 
与 找 回 密码 入 口 两 个 部 分 ， 其 中 index.php 是 这 个 网 站 的 首页 。 
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PHP 动态 系统 


index.php 


detail.php update.php 


图 3-1 PHP 动态 系统 结构 图 


在 本 地 的 计算 机 设置 站 点 服务 器 ， 在 Dreamweaver CS 5.5 的 网 站 环境 中 可 以 按 (F12) 


键 来 浏览 网 页 ， 还 可 以 在 IE 浏览 器 输入 “http:/localhosVphpweby/index.php” 来 打开 用 户 系统 
的 首页 index.php， 其 中 phpweb 为 站 点 名 。 
在 实例 中 ， 会 使 用 到 以 下 5 个 页 面 ， 整 个 网 站 的 架构 束 如 表 3-1 所 示 。 


表 3-1 PHP 动态 功能 网 页 设计 表 


页 面 名 称 J 能 
index.php 系统 首页 用 来 显示 记录 清单 
detail.php 显示 记录 详细 信息 页 面 
add.php 添 增 记 录 页 面 
update.php 更 新 记录 页 面 
del.php AN ER EKE rt 


index.php 用 于 浏览 数据 库 内 记录 ， 为 detail.php 提供 附带 URL 参数 ID 的 超级 链接 ， 便 
于 得 看 详细 的 记录 信息 ， 如 图 3-2 所 示 。 
A PHP 动 态 系 统 - Nicrosoft Internet Explorer DER) 
ax 


WHF AmE EAM Kwa) IAM) 和 帮助 H) 
OGAE- O-[9 à (5 sS kax O 由- AGL 
地 址 D) Æ] http: //127. 0.0. 1/phpweb/ index. php < 二 输入 关键 词 搜索 M I^ EZ 链接 Qsnagrt [Sj 


PHP 动 态 系统 


共有 10 笔 记录 ， 目 前 查看 第 1 笔 至 第 5 笔 
姓名 年 龄 
test1 
test2 
test? 
testd 
test5 


H 
2 
3 
4 
3 


4B Internet 


图 3-2 index 页 面 效果 


detail.php 用 于 接收 由 index.php 传 来 的 URL 参数 ID, AH URL. 参数 往 选 数据 库 中 的 记 
录 。 更 新 与 删除 记录 都 是 依据 数据 库 中 的 主键 字段 ID 来 识别 记录 的 ， 如 图 3-3 所 示 。 


^ zT 


A 详细 页 面 = Kicroso ft Internet Explorer 

XO) RED 查看 WW) 收藏 如) IAM $8500 

QAE- O-|[d(ddé PDs* kiak 6€ A aB 

HEHE M) |] http: //12T. 0. 0. 1/phpweb/detail.php?ID-1 二 输入 关键 词 搜索 €-Ejes ue Qsscc 国 


PHP 动 态 系统 


Dd 
100 


3-3 detail.php 页 面 效 果 


当 制 作 一 个 PHP 动态 网 站 时 ， 事 前 规划 网 站 的 架构 是 一 件 很 重要 的 事情 。 这 个 网 站 在 
设计 人 员 的 脑子 里 要 有 一 个 骏 形 ， 如 大 概 有 哪些 页 面 、 页 面 间 的 关系 如 何等 。 数 据 库 的 如 构 
规划 也 是 一 样 的 ， 如 要 有 哪 坚 数据 表 、 和 字段 ， 如 何 跟 网 页 配合 等 ， 都 是 很 重要 的 事情 。 


c 创建 用 户 数据 库 


PHP 动态 系统 的 功能 分 析 发 现 ， 这 个 数据 库 应 该 包括 DD、 姓 名 、 年 龄 、 成 绩 等 4 个 字段 。 
所 以 在 数据 库 中 必须 包含 一 个 容纳 上 述 信 息 的 表 ， 将 数据 库 命 名 为 phpweb. 。 接 下 来 要 在 
MySQL 建立 网 站 数据 库 作 为 任何 数据 得 询 、 痢 增 、 修 改 与 删除 的 后 端 文 持 。 制 作 的 步骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL", YEA MySQL 数据 库 的 管理 面 
板 ， 如 图 3-4 所 示 。 

(2) 单 击 工具 栏 的 Create GD) 按钮 ， 并 在 打开 的 下 拉 沈 单 中 单 击 选择 “Database 
(数据 库 )” 命 令 ， 如 图 3-5 所 示 。 
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3-4 打开 MySQL 数据 库 3-5 ĦAJ% “DataBase” MeS 
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(3) 打开 “Create DataBase Wizard (建立 数据 库 同 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
^phpweb". 然后 再 单 击 Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 如 图 3-6 所 示 。 


Create Database 


Specify the name for a new database 


Welcome to the Create Database Wizard! 
This wizard allows you to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SQL statement for creating the database and execute it 
on MySQL server. 


SQL 
mm- Manager Database name phpweb 
。 forMySQL 


Register after creating 


图 3-6 输入 数据 库 的 名 称 phpweb 


(4) 设置 MySQL 数据 库 的 属性 设置 如 表 3-2 所 示 ， 连 接 设 置 如 图 3-7 所 示 。 然 后 再 单 
iH Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 


表 3-2 数据 库 属性 设置 


Host name localhost Port 3306 
User name root 
Password admin 


Create Database Wizard 
Create Database 


Set connection properies for a new database 


Host name localhost v | Port 


User name 


| 
Password | 


Lise server settings 


allation 


[C] Use tunneling 
Tunneling 


5H tunneling 


图 3-7 “数据库 连接 设置 
(5) 打开 新 建 数据 库 的 SQL 语句 提示 创建 数据 库 phpweb， 直 接 单 击 Next (下 一 步 ) f 


钮 ， 如 图 3-8 所 示 。 
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Create Database Wizard 
Create Database 
Result SOL statement. Click the Finish button to create a new database. 


Result SiL statement: 
CREATE DATABASE "phpweb': 


- for MySQL 


E TR 


Click "Finish" ta create the database. 


图 3-8 ”完成 设置 


(6) 单 击 Finisnh《〈 完 成 ) 按钮 ， 打 开 注 册 数 据 库 的 设置 男 面 ， 在 选择 utf8 FHR, fA 
中 文 版 的 GB2312 版 ， 其 他 的 保持 默认 值 ， 如 图 3-9 所 示 。 本 书 用 Dreamweaver 创建 的 php 
网 页 默认 的 字符 集 格式 是 charset=utf8， 所 以 建立 的 MySQL 格式 全 部 为 utf8。 


Database Registration Info 


$^ Connection 
I | Display Options Host name 


I Directories User name 


ant 
HTTP Tunneling Database name hpweehb 
fa 


v 
IE] Data Options 


Database alias Phpwweb an localhost 


Font charset GB2312 CHARSET (Simplified Chinese charak k 


图 3-9 ”选择 简体 中 文 版 


(7) "Pali OK 人 确认) 按钮， 就 完成 了 数据 库 phpweb 的 新 增 工作 。 

数据 库 建立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 是 websql. ££ 
立 数据 库 后 ， 接 着 再 按 左 边 的 “Connect to Database (连接 数据 库 )” 图 标 电 将 其 连接 上 ， 这 
张 数据 表 的 字段 结构 内 容 说 明 如 下 。 

(1) 建立 数据 库 phpweb 后 ， 用 鼠标 右键 单 击 选 择 “Table 〈 表 格 )” 选 项 ， 在 打开 的 来 
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单 中 单 击 选择 “New Table (新 表格 )” 命 令 ， 如 图 3-10 所 示 。 

(20 数据 库 右 方面 向 会 出 现 新 建 数据 表 (Table) 的 设置 区 域 , 含有 “Table (表格 )”、 
“Fields (内 容 )”、“DDL KI)” 3 个 选项 卡 ， 先 在 “Table (表格 )” 中 输入 数据 表 名 
websql， 如 图 3-11 所 示 。 


g Hew Table — [phpweb on localhost] 


— me ae 
Table Properties 


| E phpweb on localhost [php' {v 


Table name websgl 


co E o Storage Options 


g Compile Storage engine MyISAM] 


@) Show SQL help | Row format DEFAULT 
|! [E Restore default size || Min. rows 


<><> 


Mew Table... Ctrlthy 
a 


III Refresh Tables F5 


了 Auto increment value 


0 
7 Max. rows 0 
0 


p Average row length 


<*> < < 


= Database Registration Info... «| Size for index key blocks 0 


[C] Check sum [C] Delay key write 
[ ]Pack keys C] Temporary 


Character Sets |File Options | Merge Table Options | Federated Table Options 
Character set Default v 
Collation Default v 


3-10 ”开始 建 数据 表 3-11 输入 数据 表 名 websql 


(3) 然后 再 切换 到 “Fields (内 容 )” 选 项 卡 中 ， 输 入 数据 域名 以 及 设置 数据 域 位 的 相关 
数据 ， 如 图 3-12 所 示 。 


New Tab from Here... 


Rename Curent T ab... 


Delete Current T ab 
Find Item... Ctrl+F 


g Table — [websgl] - [phpweb on localhost] 
Object Al | Properties | Fields Indices | Triggers || Data | Dependencies | DDL 


Field Name Field Type — Size Preci... Not N... Default Comment 
[3 phpweb on localhost [p sv " 
3 ) i D Null 
Eg websgl v | 


General A " 


[a] Refresh 


f Compile 

Qs Grants on table 

ca Print 

9) Show SQL help 

d Table Editor options 
[EF] Restore default size 


3-12 ”设置 数据 库 字段 
各 字段 如 表 3-3 所 示 。 这 个 数据 表 主 要 是 记录 每 个 用 户 的 基本 数据 和 成 绩 。 


表 3-3 websql 数据 表 


字段 名 称 字段 型 态 说 明 
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也 可 以 直接 在 DOS 的 MySQL 输入 管理 状态 下 和 直接 创建 数据 表 ， 实 现 的 命令 如 下 : 


CREATE TABLE ‘websgl ( 
"ID? int(11) NOT NULL AUTO INCREMENT, 
"Name' varchar(20) DEFAULT NULL, 
"Age tinyint(4) DEFAULT NULL, 
"Result. varchar(20) DEFAULT NULL, 
PRIMARY KEY CID)) 

) ENGINE=MyISAM DEFAULT CHARSET=utf8; 


(4) 为 了 下 面 页 面 制作 的 调用 需要 ， 可 以 事先 在 数据 表 里 加 入 10 笔 数 据 ， 单 击 “Date 
(数据 )” 选 项 卡 ， 在 数据 表 手 动 加 入 名 为 testl~testl0 的 10 个 用 户 ， 年 龄 和 成 绩 也 编辑 不 同 
的 数据 ， 如 图 3-13 所 示 。 


Æ Table — [websgl] - [phpweb on localhost] 


Object Al | Properties | Fields | Indices | Triggers | Data | Dependencies DDL | 
d a e A EAHA E Me 


[3 phpweh on localhost [p v 
时 websq v 


i WY name * age ** Result v 
= 
(g) Refresh zi bii. 
3 test3 


| 学 Compile 4 testd 
由 Ss Grants on table 5|test5 

e» Print B5 teste 
T testT 
€) Show SQL help e[testa 
dh Table Editor options S|test9 


Restore default size 10 test10 


Grid view Form View Print Data 


a Commit transaction Records fetched: 10/10 Open Time: 32 ms LIMIT 0, 1000 


图 3-13 加 入 10 笔 数 据 


3.2.3 定义 phpweb 站 点 | 


在 Dreamweaver CS 5.5 中 创建 一 个 “PHP 动态 系统 ”网 站 站 点 pppweb， 由 于 这 是 PHP 
数据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 堪 ， 主 要 的 设置 如 表 3-4 Hrs. 


表 3-4 站 点 设置 的 基本 参数 


站 点 名 称 phpweb 
本 机 根 目录 CAApacheMtdocsphpweb 
测试 服务 器 CAApacheMtdocsV 
网 站 测试 地 址 http://localhosU/phpweb/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All Users\Application DataMySQL\MySQL Server 5.5\data\phpweb 
管理 账号 / 密码 root / admin 
数据 库 名 称 websql 


创建 phpweb 站 点 具体 操作 步骤 如 下 。 


第 3 草 | Dr eamweave r+PHP 开 发 基础 


(1) 首先 在 C:\Apache\htdocs 路 径 下 建立 phpweb 文件 夹 ， 如 图 3-14 所 示 ， 本 章 所 有 建 
区 的 网 页 文件 都 将 放 在 该 文件 夹 下 。 

(2) 运行 Dreamweaver CS 5.5， 选 择 荣 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 3-15 PTR. 


-\Apache\htdo 
Xo) BB) Woo Mw TAa) Mhon 

QAR- O- Ø ARR ox" [3 

IAS D) 1 C: AApocheihtdves bl? Los 


` azau 

XH X PEXCUESS ! | meServerScripis 2011-1-11 10:5? 

2011-1-20 15:36 
m) Ee » 
gy BETIA VM bb egens 
[) SUE TEX 文件 2011-6-45 9:41 
C UxTIMEROWUm in XM 2011-7 9/35 

Yab 


2011-6-30 15.30 
= ERER 2011-T-i1 18.49 
O BANT im 2004-11-20 15:16 


Q "W 21176 0: 
BERTIE st 
x ET 2011-1-29 10:14 


编辑 (ED... 
FAE] 
HEF E] 

导出 M)... 


3-14 ”建立 站 点 文件 夹 pppweb 3-15 “管理 站 点 ”对 话 框 


(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 上 所 有 已 经 定义 的 站 点 。 单 击 右边 的 “新 
建 ” 投 钮 ， 打 开 “ 站 点 设置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 

"yh: phpweb 

“本 地 站 点 文件 来” ”C:\Apache\htdocs\phpweb\ 

如 图 3-16 所 示 。 


站 点 设置 对 人 鳃 phpweb 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。Drearmweaver 
站 点 通常 常 包含 两 个 部 分 ， 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 发 布 和 到 web 上 的 服务 器 上 的 远程 文件 夹 。 


您 可 以 在 此 处 汶 Dreamweaver 站 点 选择 本 地 立 件 来 和 名 称 。 
zE Hi sd d reb: | C'\Apachehhtdocs\phpweb\ F3 


3-16 ££ phpweb 站 点 


(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 此 |， 打 开 “ 基 本 ” 


选项 卡 ， 进 行 如 图 3-17 所 示 的 参数 设置 。 
“服务 磺 名 称 ” phpweb 


PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


“连接 方法 本地/ 网络 
“服务 需 文 件 严 ” CNApacheMitdocs 
“Web URL”: http:// localhost/phpweb. 


站 点 设置 对 和 锡 phpweb 
服务 器 名 称 ; 
连接 方法 ;| 本 地 /网 络 | 
服务 器 文件 夹 ! [ciapachetdos ë ë ë OS 
Web URL: | http://127.0.0. 1/phpweb/ 


3-17 设置 “基本 ”选项 卡 


(5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同步 
言 息 ” 复 选 按钮 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 


的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 3-18 所 示 。 


靖 点 设置 对 旬 phpweb 


版 本 控制 远程 服务 器 
* ”高 级 设置 M 维护 同步 信息 
O 保存 时 自动 将 净 件 上 传 到 服务 器 
O 启用 文件 取出 功能 


[V] 打开 文件 之 前 取出 


取出 名 称 : 


电子 邮件 地 址 : (00000000000 


3-18 设置 “高 级 ”选项 卡 
(6) 单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 勺 选 “ 测 试 ” 复 选 按钮 ， 
如 图 3-19 所 示 。 
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WAKAS phpweb 


Li 您 将 在 此 位 置 选择 承载 Web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 


服务 器 LED : 1 
版 本 控制 Internet 服务 提供 商 (ISP) 或 web 管理 员 。 


* ”高 级 设置 


注意 ; 要 开始 在 Dreamweaver 站 点 上 了 工作， 您 无 需 完成 此 步 又 。 如 果 要 和 连接 到 web 并 发 
布 页 面 ， 您 只 需 定 义 一 个 远程 服务 器 即 可 。 


| 地 址 | 连接 | 远程 | T 


C:lApachejhtdocs/ 本 地 | 网 络 (V 


图 3-19 设置 “服务 器 ”参数 


单 击 “保存 ”按钮 ， 则 完成 站 点 ORE REOR. 在 Dreamweaver CS 5.5 rk Gg T Wi 
才 所 设置 的 站 点 phpweb。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 杠 ， 这 样 就 完成 了 
Dreamweaver CS 5.5 测试 PHP 动态 系统 网 页 的 网 站 环境 设置 。 


CA 设置 数据 库 连 接 

完成 了 站 点 的 定义 后 ， 接 下 来 就 是 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 连接 
设置 如 下 。 

(1) 执行 肖 单 栏 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 index.php 的 
网 页 ， 输 入 网 页 标题 “PHP 动态 系统 ”， 然后 执行 过 单 “文件 ”一 “保存 ”命令 将 网 页 保 
存 ， 如 图 3-20 所 示 。 


| Dw (ww (B — Qor CSRS 
ECION wiw mco Ww w WO) 490) WACG) wncmn Who 
C geraden mthin pte 


"vob MA 4 MA. ML M. RU. SHE v. Co Wm ness 
25507 dau [/Ag v te "m 


MIO n vn Ari we oe) 


v BJ Eius 
"Qo Www 


3-20 ”创建 空白 网 页 


- aA : 
" 
PHP+ 


(2) 单 击 选择 滋 单 栏 上 的 “窗口 ”一 “数据 库 ” 命 令 ， 打 开 
“数据 库 ” 面 板 。 在 “数据 库 ” 面 板 上 单 击 选择 “+” 图 标 ， 并 NEN 
在 打开 的 菜单 中 选择 “MySQL 连接 ”选项 ， 如 图 3-21 所 示 。 

(3) 在 “MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 | ” i hime kuowcm. 
webconn、“MySQL 服务 右 ” 名 为 localhost、“ 用 户 名 ”为 root. 
密码 为 admin， 如 图 3-22a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 图 3-21 XPE MySQL 连接 
称 ， 可 以 单 击 “选取 ”按钮 ， 浏览 MySQL 服务 左上 的 所 有 数据 库 。 选 择 刚 寻 入 的 范例 数据 
JÆ phpweb， 具 体 的 设置 内 容 如 图 3-22b 所 示 。 


NySQL 连接 


连接 名 称 : webconn 
MySQL 服务 器 : localhost 
HAPA: root 
JY, oekkk 
数据 库 : phpweb 


图 3-22 设置 MySQL 连接 参数 


(4) 早 击 “测试 ”按钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 果 正 人 确 ， 则 出 一 个 
消息 枉 ， 如 图 3-23 所 示 这 表示 数据 库 连 接 设 置 成 功 。 - 

单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ?” 
面板 中 则 显示 绑 定 过 来 的 数据 库 ， 如 图 3-24 Br. 

在 建立 完成 MySQL 连接 后 ， 在 “文件 夹 ” 面 板 中 会 
看 到 Dreamwaver 目 动 建立 了 Connections 文件 夹 ， 在 该 文 图 3-23 设置 成 功 
件 夹 下 有 一 个 与 前 面 所 建立 的 MySQL 连接 名 称 相同 的 文件 ， 如 图 3-25 所 示 。 


文件 jiRil 
gre BE [23 phpweb v 本 地 视图 v 
二 一 THA. PHP C EX c | AQ | = 


=] webconn. ph 1KB PHP XU 
: A Ta age (tinyint 4] To index. php B JEETHESUE 
M us: ID (int 11 必需 的 ) E 
ines Hh mame ivar char 20) 
CE ow Hh Result [lvarchar 20) 
a A 视图 
DE NE ct: 
< 山 > 
(Q ec 


图 3-24 SEXE 图 3-25 目 动 生成 的 文件 
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Connections 文件 夹 是 Dreamweaver 用 来 存放 MySQL 连接 设置 文件 的 文件 来。 打开 该 文 
件 并 使 用 “代码 ”视图 ， 可 以 看 到 连接 数据 库 的 设置 ， 如 图 3-26 所 示 。 
Dw co cr 


WH 编辑 (EF) 查看 (VY) HAM 修改 (格式 名 ) 命令 (C5) 站 点 (5) 窗口 (由 8H) 
C:\Apache\htdocs\phpweb\Connections\webconn. php i 


&oo0»nag|m 


D 


?php 
2 # FileName=" Connection php mysql.htn" 
# Type-"MYSQL" 
# HTTP="true" 
$hostname webconn = "localhost"; 
$database webconn = "phpweb"; 
$username webconn - "root"; 
$password webconn = "admin"; 
$webconn = mysql pconnect($hostname webconn, $username webconn, $password webconn) or 
trigger error(mysql error(),E USER ERROR); 
?> 


« B) t3) (Ez) [«] $e [4] mx Iam 


1 K/1 $9 Unicode (UTF-8) 


[Om] | 格式 中 | 无 ~) 类 BI 
Bi css ID) 链接 (L) 


TREE... 列表 项 目 « =) 出 | 
®© 1 个 本 地 项 目 被 选中 $ (HE) 


3-26 数据库 连接 设置 


在 这 个 文件 中 定义 了 与 MySQL 服务 器 的 连接 (mysql_pconnect Kr), GHA FA 


y 


$hostname: MySQL 服务 器 的 地 址 。 

$database: 连接 数据 库 的 名 称 。 

$username: 用 户 名 称 。 

$password: HP i. 

XE XJ 4E 53 E Bu EKES ran Pr EE ELIO] NLIS A aA H ERU mysql_connect 与 数据 
库 连 接 。 连 接 后 才能 对 数据 库 进 行 得 询 、 新 增 、 修 改 或 删除 的 操作 。 

如 果 在 网 站 制作 完成 后 将 文件 上 传 至 网 络 上 的 主机 衬 间 时 ， 发 现 网络 上 的 MySQL 服务 
器 访问 的 用 户 名 、 密 人 码 等 方面 与 本 机 设置 有 所 不 同 ， 可 以 直接 修改 位 于 Connections 文件 夹 
下 的 webconn.php 文件 。 


检查 数据 库 记录 


本 小 节 将 介绍 在 Dreamweaver 中 与 检查 数据 库 记 录 相 关 的 “服务 器 行为 ”主要 包 
括 记 录 集 、 插 入 记录 、 更 新 记录 、 重 复 区 域 、 显 示 区 域 和 记录 和 集 分 页 等 常用 的 动态 服务 
8811 NJ « 
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创建 记录 集 ) 

在 每 个 需要 奋 看 数据 库 记 录 的 页 面 中 缘 须 为 其 建立 一 个 “记录 集 《〈 碍 询 )”， 从 而 可 以 让 
Dreamweaver 知道 ， 目 前 这 个 网 页 中 所 需要 的 是 数据 库 中 的 哪些 数据 。 即 便 需 要 的 内 容 一 
样 ， 在 不 同 网 页 也 需要 单独 建立 。 同 一 个 数据 库 只 需 建 立 一 次 MySQL 连接 ， 但 可 以 为 同一 
个 MySQL 数据 库 连 接 建立 多 个 “记录 集 ”， 配 合租 选 的 功能 ， 达 到 茶 个 记录 集 只 包含 数据 
库 中 符合 某 些 条 件 的 记录 。 

打开 index.php 文件 后 ， 选 择 末 单 栏 上 的 “应 用 程序 ”一 “ 绑 定 ”和 面板 ， 选 择 “ 记 录 集 
(查询 )” 便 可 以 建立 记录 集 。“ 应 用 程序 ”一 “ 绑 定 ”面板 中 的 “记录 集 (查询 )” 与 “服务 
器 行为 ”面板 中 的 “记录 集 ” 是 相同 的 。 如 图 3-27 所 示 。 


LE 一 文档 类 型 : PHP 
记录 集 ( 查询 ) 


表单 变量 
UL 变量 
阶段 变量 
Cookie WE 
服务 器 变量 
环境 变量 


Spry 数据 集 
获 职 数据 源 ... 


图 3-27 选择 “记录 集 ” 命 令 


按说 明 设 置 各 项 如 图 3-28 PIR, Wan AA MA” JE, Dreamweaver 会 显示 日 
前 设置 所 返回 的 记录 集 内 所 有 记录 。 字 段 的 功能 说 明 如 表 3-5 所 示 。 


表 3-5 字段 与 功能 说 明 


字 R 说 ”有明 
名 称 一 般 用 Recordset (记录 集 ) 的 缩写 rs 作为 开头 
连接 选择 所 建立 记录 集 的 数据 库 是 在 哪个 MySQL 连接 
列 此 处 显现 该 数据 库 连 接 中 所 有 的 数据 表 ， 以 及 所 选 数据 表 内 所 有 字段 
ffr zE fi A US AE T EH Ae io 
排序 是 否 依照 某 个 字段 值 进行 排序 。 比 如 ， 在 新 闻 系 统 中 需要 把 新 的 新 闻 放 到 前 面 位 置 ， 就 可 以 
使 用 排序 的 功能 


EKE EW” EHAKE SELECT 语句 ， 因 为 全 询 出 来 的 结果 可 能 会 有 很 多 条 ， 
所 以 称 为 “记录 和 集 ( 合 )”， gf "juve" S WD WHERE Tfj. 
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名 称 : |Rsdb| 
连接 : webconn 
表格 : |websql 
5.0 全 部 O mm: 


图 3-28 设置 “记录 集 ” 


单 击 “测试 ”按钮 后 ， 可 以 看 到 返回 的 记录 。 因 为 没有 做 任何 科 选 的 处 理 ， 所 以 会 返回 
完整 的 所 有 记录 ， 如 图 3-29 所 示 。 


测试 56L 指 仿 


Eu 
Ei 


testB 
testT 
testā 
test 
testlü 


= n co —1 cn (n a4» 603 P3 一 


= np co —1 cn (n 4» 63 To 一 m 
e 


e 


piest (P2 下 25 个 H) 


图 3-29 单 击 “测试 ”按钮 浏览 记录 和 集 


可 以 单 击 “高 级 ”按钮 查看 该 SQL 语句 。 可 以 看 到 ，Dreamweaver 提供 了 一 个 基本 的 
图 形 界 面 ， 实 际 上 它 会 生成 相应 的 程序 代码 。 在 “高 级 ”窗口 中 可 以 看 到 相应 的 SQL iE 
AJ WAI 3-30 所 示 ， 男 外 还 提供 加 入 变量 、 修 改 SQL 语句 的 功能 ， 用 以 满足 使 用 简单 图 形 
界面 设置 无 法 满足 的 情况 。 

在 记录 集 建 立 完 毕 后 ， 可 以 在 “应 用 程序 ”一 “ 绑 定 ”面板 中 得 看 到 目前 页 面 里 的 所 有 
记录 集 ， 以 及 各 记录 集中 的 字段 ， 双 击 记 录 集 可 以 重新 打开 图 3-31 所 示 的 设置 窗口 。 
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: 


: |webeorm 


: |SELECT * 
FROM websql 


添加 到 SQL: 
Cmm) 


WHERE 


ORDER BY 


图 3-30 “高 级 ”记录 集 窗 口 图 3-31 绑 定 的 记录 集 效 果 


建立 记录 集 与 直接 写 SELECT 语句 是 相同 的 ， 将 页 面 切换 到 “代码 ”视图 ， 如 图 3-32 
所 示 。 其 中 第 1 行 的 require once 函数 是 用 来 引入 文件 的 ， 即 前 面 介绍 过 的 webconn.php。 
在 Dreamweaver 中 ， 帮 是 已 经 定义 好 数据 库 连 接 ， 那 么 在 其 他 建立 记录 集 、 更 新 记录 、 插 入 
记录 、 删 除 记录 的 页 和 面 中 ， 这 个 连接 设置 文件 就 会 在 页 面 的 最 前 面 被 引入 《这 束 是 为 什么 在 
同一 个 站 点 中 只 需要 定义 一 次 MySQL 数据 库 连 接 )， 因 为 该 文件 中 所 包括 的 与 数据 库 连 接 
相关 的 设置 需要 被 使 用 。 


"5. C: ipacheWhtdocsVphpweblindez.php (XIHTIL)# -0x 
CHAED webconn. php T 
r3 1 <?php require once('Connections/webconn.php']); ?> ^ 
- BENE ov» J 
3 if (!function exists("GetSQüLValueString")) ( 
4 function GetSQLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "") 
p? 5 E 
+». 6 if (PHP VERSION < 6] { 
= 7 $theValue = get magic quotes gpcí() ? stripslashes($theValue) : $theValue; 
* EE: } 
9 
e B $theValue = function exists("mysql real escape string") ? mysql real escape string($theValue) : mysql escape string( 
全 $theValue); 
TL 
Em n switch ($theType) { 
— B case "text": 
Sg 14 $theValue = ($theValue != "") ? "'" , $theValue . "'" : "NULL"; 
RS break; 
fo) l6 case "long": 
— Bg case "int": 
(3 l8 $theValue = ($theValue !- "") ? intval($theValue) : "NULL"; 
M 19 break; 
(5 20 case "double": 
cg $theValue = ($theValue !- "") ? doubleval($theValue) : "NULL"; 
AED break; 
& ER) case "date": 
dh, 24 $theValue = ($theValue != "") ?» "'" , $theValue . "'" : "NULL"; 
25 break; 
ER 26 case "defined": — 
+= 27 $theValue = ($theValue !- "") ? $theDefinedValue : $theNotDefinedValue; 
ES break; 
& 29 
30 return $theValue; 
31 
32 } 
34 mysql select db($database webconn, $webconn); 
5 $query Rsdb - "SELECT * FROM websql"; 
36 $Rsdb = mysql query(s$query Rsdb, $webconn) or die(mysql errorí)): 
EE Srow Rsdb = mysql fetch assoc($Rsdb): 
$tntralRowa Radh = mvarrl num rnwaí$Randh!: v 
3K/1 fb Unicode (UTF-8) 


3-32 BEI 
其 程序 具体 分 析 如 下 。 
(1) 第 34 行 引用 了 webconn.php 内 的 设置 (变量 $datebase_webconn 与 $webconn 被 定义 在 这 
个 文件 中 ) 来 选择 数据 库 (mysql_select db0)， 随 后 的 mysql_query() 所 作用 的 都 是 此 数据 库 。 
(2) 第 35 行 定义 了 查询 数据 库 的 SQL 语句 。 
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(3) 第 36 行使 用 第 35 行 所 定义 的 SQL 语句 对 数据 库 执 行 租 询 操作 (mysql_queryO )， 
此 时 返回 结 末 是 资源 标识 和 侍 ， 还 不 能 被 使 用 。 

(4) 第 37 行将 前 面 查 询 的 结果 以 关系 型 数组 的 形式 (mysql_fetch_assoc()) 传 到 变量 
$row_Rsdb， 然 后 融 可 以 使 用 $row_ 记录 集 名 称 [学 段 名 称 '] 来 取得 记录 集 字 段 值 。 | 

(5) 第 38 列 取 得 查询 结果 的 记录 条 数 Cmysgl num_rowsO0 )， 并 赋 给 变量 $totalRows — B 
Rsdb 。 

(6) 最 后 mysql free result FE JA & vy zi R d H BRA EE SER o 

上 面 是 Dreamweaver 连接 数据 库 并 执行 得 询 的 标准 步骤 ， 在 mysql query($query. Rsdb, 
$webconn) or die(mysql_errorO) 的 部 分 ， 寿 or 前 和 面 语句 出 现 铺 误 或 失败 ， 就 执行 or 后 面 的 程 
序 。 所 以 者 数据 库 得 询 失 败 的 时 候 了 驶 会 产生 错误 信息 ， 并 终止 程序 的 运行 。 

在 一 般 PHP 程序 中 ， 典 型 的 连接 与 得 询 程序 类 似 下 面 的 例子 。 


mysql select db($database webconn, $webconn); 

$query_Rsdb = "SELECT * FROM websql"; 

$Rsdb = mysql query(Squery. Rsdb, $webconn) or die(mysgql error()); 
$row Rsdb = mysql fetch assoc($Rsdb); 

$totalRows Rsdb = mysql num rows(SRsdb); 

mysql free result($Rsdb); 


可 能 会 觉得 Dreamweaver 产生 出 来 的 程序 代码 比较 复杂 ， 这 是 因为 Dreamweaver ££ 
的 记录 集 需 要 搭配 很 多 服务 器 行为 来 使 用 。 


Seo 显示 记录 功能 
接 独 要 将 记录 集 内 的 记录 《〈 即 数据 库 中 的 数据 ) 直接 显示 到 网 页 上 ， 实 现 的 步 又 如 下 。 


CD 在 “文件 ”面板 中 打开 index.php， 在 网 页 中 制作 一 个 如 图 3-33 所 示 的 2x4 表格 ， 
然后 在 “应 用 程序 ”一 “ 绑 定 ”面板 ， 选 择 所 需 的 字段 并 拖 动 到 表格 中 。 


A C: hpachevht docsAphpwebvindex, php (XHTML) * zm 
CHAED webconn.php T 
PHP 动 态 系统 

me RE ipe 成 项 
| (Rsdb.ID] | (Rsdb.name) (Rsdb. age) (Rsdb. Result) 
body? [Kn (RIS Q 100$ v646 x 254v 4 K / 1 $5 Unicode (UTF-8) 


图 3-33 SEE 


(2) 在 使 用 鼠标 拖 动 字段 全 页 面 上 放 开 后 ， 会 出 现 {Rsdb.name} 的 字样 ， 其 中 Rsdb 为 记 
KRAP, name 为 字段 名 称 。 将 序号 、 姓 名 、 年 龄 、 成 绩 4 个 字段 分 别 拖 全 相应 的 单元 格 


IPHP+ 


后 ， 单 击 | 实时 视图 | 按钮 。 
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视图 所 呈现 的 效果 与 使 用 浏览 如 打 开 网 页 一 样 ， 原 本 仪 显 示 { 记 录 集 名 称 .字段 名 称 } 的 部 


分 将 会 显示 出 记录 和 集 内 的 记录 ， 如 图 3-34 所 示 。 


Dw | wn | ET O um 
文件 (7) 编辑 (EF) 查看 (VY) 插入 (I) ERM 格式 (0) 命令 (C5) ”站 点 (5S) 窗口 (加 RH) 


indez. php X C:\Apache\htdocs\phpweb\indez. php 


Phat webconn.php 
E WE EAE RB A (REEE t OLARE C 35: 
LG O E OME ier 2 0.0 orini 本 上 E 


PHP 动 态 系统 


[一 HT | E | E 
| 1 test1 | 21 | 100 


& Gios59:8|7 


日 © 站 点 - phpweb (C... 
四- Connections 
775 add php 
P del. php 

<body. ca? <table> <tbody> <tr> <td> <a> 100% ~|678 x 382v 4 K / 1 f» Unicode (UTF-8) sT detail. php 

T5, index.php 

o update. php 


图 3-34 ”实时 视图 效果 


(3) 再 单 击 一 次 | 实时 视图 | 按钮 ， 将 页 面 切换 到 | 代码 视图 ， 可 以 看 { 记 录 集 名 称 .字段 名 


称 } 部 分 的 代码 ， 在 该 程序 代码 中 使 用 echo 来 输出 字段 值 ， 如 图 3-35 所 示 。 


Dw | wir ”| © cue 
AEG 编辑 (EF) 查看 (VY) 插入 (IT) EHM RAO 命令 (5C) 站 点 (3) gO ARH 


indez.php* X C: XApachekht docskphpweb*indez. php 


HAD webconn. php 


(FB | 设计 | | 实时 代码 LV A RNE | 检查 N Qo 多 屏 大 |v 0 00 dme pe 
i & o C ay Hu: £i1e:///C |/Apache/htdocs/phpweb/index.php 
58 <table width-"600" border="1" align-"center" cellpadding-"l" cellspacing-"1"» 
<tr> 
<t 中 序号 < jtq> 
«toS ca 
<td 年 龄 < /td> 
<t 中 成 绩 < /tq> 
x/tr» 
<tr> 
Rer «w-?php echo $row Rsdb['ID']; ?> 全 和 
<td><?php echo $row Rsdb['name']; ?></td> 
<td><?php echo $row Rsdb['age']; ?»2«/td» 
<td><?php echo $row Rsdb['Result']; ?2«/td» 
</tr> 
</table> 
<hr /> 


artic | ETE 
&cdjoorae|m: 


mysql free result($Rsdb); 
?- 


Connections 
; add. php 
o del. php 


4K/1 f? Unicode (UTF-8) J Bn 
CT index.php 


L. © update. ph 
eoz y] x v| B7 BSSsasan|]  — is 
bcs o mo 链接 中 — à oD Hio i 
国 单元 格 KFU ~v aw) | mao WREeO OLI — | [ m 
一 oğ ampu ~v o | saw € sx 


3-35 代码 视图 效果 
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c 重复 区 域 功能 : 


现在 只 能 看 到 记录 集中 的 第 1 条 记录 ， 那 后 面 的 记录 如 何 显示 出 来 呢 ?Dreamweaver t > 


供 了 “重复 区 域 ” 及 “记录 集 分 页 ”的 功能 ， 只 需要 鼠标 拖 动 ， 就 可 以 实现 这 个 功能 。 
选取 需要 重复 的 部 分 ， 即 表格 中 的 第 2 行 ， 如 图 3-36 所 示 ， 然 后 在 “服务 器 行为 ” 面 
板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 于 单 中 选择 “重复 区域” 命令 ， 如 图 3-37 Bp. 


显示 区 域 
显示 记录 计数 d 
动态 女 本 


插入 记录 


更 新 记录 

册 除 记录 

动态 表单 元 素 d 
PHP 动 态 系统 用 户 身份 验证 d 


XSLT 转换 


编辑 服务 器 行为 . .. 
新 建 服务 器 行为 . .. 
获 职 更 多 服务 器 行 汶 ... 


| (Rsdb.ID) (Rsdb.name) (Rsdb.age) (Rsdb. Result) 


图 3-36 选取 表格 第 2 行 图 3-37 选择 “重复 区 域 ”命令 


之 所 以 要 确认 选取 的 标签 为 <e ， 是 因为 重复 区 域 会 使 用 do...while 循环 包围 所 作用 
的 范围 。 而 需要 重复 的 仅 是 第 2 行 的 表格 ， 在 HTML 中 表格 的 行 是 使 用 str> 标 签 。 确 认 选 取 
的 标签 正确 ， 执 行 时 才 不 会 发 生 错 误 。 

此 时 会 弹出 一 个 窗口 ， 如 图 3-38 所 示 ， 要 求 选 择 要 重复 记录 的 记录 集 ， 以 及 需要 重复 
儿 条 记录 或 显示 全 部 记录 。 同 样 地 选择 | 实时 视图 |， 这 时 就 可 以 看 到 原来 只 有 两 行 的 表格 已 经 
增长 到 6 行 ， 如 图 3-39 所 示 ， 而 记录 集 内 的 前 5 条 记录 都 已 显示 在 页 面 上 。 


Dw asm + | FE O Gu 


| iatz ste Serristgmti: 
CIRIP sama pio 
Ahn me T RRA o "mam &m o. Oos (C ff 7 
[e] QU ttp /2 0 0 1/5) inde. pèp - n 
PPA DE 


1008 ë = Oai SE/1 uice UTI) 


Bx wv »4 uuum 
. «»T "i0 io 
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图 3-38 设置 重复 区 域 图 3-39 ”实时 预览 效果 
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所 有 页 面 上 的 “服务 器 行为 ”都 会 被 列 在 “窗口 ”一 “服务 器 行为 ”面板 的 清单 中 ， 在 
本 例 中 ， 选 择 重 复 5 条 记录 。 若 想 要 修改 服务 器 行为 的 设置 ， 则 可 以 通过 双击 该 服务 器 行为 
来 进行 ， 如 图 3-40 所 示 。 


复 区 域 (Rsdb) 


sdb. Name) 
(Rsdb. Age) 
(Rsdb. Result) 


3-40 ”服务 器 行为 面板 


将 页 面 切换 到 “代码 ”视图 ， 在 套用 了 “重复 区 域 ”服务 器 行为 后 ， 在 程序 代码 当 
中 的 变化 便 是 这 行 单元 格 的 上 下 被 do...while 循环 包围 了 ， 而 重复 的 条 件 为 第 87 行 语句 
如 图 3-41 所 示 ， 用 这 样 的 循环 可 以 达到 将 记录 集中 的 记录 全 部 输出 才 停止 循环 。 


DW | WH si [ol 


ES TERE SEn E Emm eA AAO MAE ”窗口 (9) Mhon 
CA gachalhi dcs phus indar 


ena RHEINE 


动态 文本 (Ridb Name) 
STE  (Erdb Ago) 


Ca eaa- E echo frot Rsdb['ID']: Peai uE 
?php -Rsdb['ID'] / HEEE Medb. Rezult) 


zEdoxPphp echo $row Rsdo['Mame']: Per 
«tiüx"php echo £row Rsdb['Age']: Pared 
“tp echo prov Rsdb['Result!']; Yi /Ed 


ctable width-"6D0" borde 
£t» 
td widthe"1437» (8— TI j« ds 
ctd widthe"14375 [B — DI 3. / cin. 
ctd widthe"143*»( Fijet 


kel & € yng 商品 | 


e ^n 


ctd width=" ldg" [MaM «orn 


up o 
c un 


50 datail. php 
^ ^ index php 
"US uwpdate. php 


LK G9. ERR 


va E:zcrigmmo O O 


d jou 目标 io) 


3-41 AXES 


在 建立 记录 集 时 就 知道 有 10 条 记录 都 在 记录 人 集中， 可 是 在 这 里 怎么 显示 了 5 条 记录 
Je? 回头 来 检查 下 代码 ， 如 图 3-42 所 示 。 


第 3 草 Dreamweaver+PHP 开 发 基础 


:pache\ht docsphpweb'inder. php [XHTHL) -Dx 


EASP webconn.php 


$naxRows Rsdh = 5; i " 

$pageNum Esdb = 0; d 

if (issetís GET['pageNMum Rsdb']]) 1 — 
spageMum Rsdb = $ GET['pageNum Rsdb']; 1 


} b. 一 三 三 
$5tartRow Rsdb = gpageNum Rsdb * $maxRows Rs; 


mysql select db(S$database webconn, £$webconn):; 

$masery Bsdb = "SELECT * FROM websql"; 

$query limit Rsdb = sprintf("5s LIMIT $d, $d", $query Esdb, $startRow Esdb, 
emaxRows Rasdb); 

sRsdh = mysql_query {$query limit Esdb, $&webconn) or dieimysql errorií)]: 
grow Esdb = mysql fetch assoc(sRsdb]:; 


if jissetis BETI['totalBReyws Rsdb']3]) 1 
$toatalRows Rsdh = $ GET['totalRows Esdb!']; 
} else 1 
$all Esdb = mysql_query {$query Esdb]; 
$tatalRows Rsdbh = myvsqi num rowsisall ERsdb]; 
} 
$toatalPages Esdb = ceilistotalEows Easdb/gmaxREows Esasdb]-1:; 
»- 


- dp TerarireTTETTOTA 1- l.. 1 TiTTTA T Tm rr J JTTÀ7Ag Bh es ee — LITTCTUET 1 -=-= --- 一 = =-=- = l l! ITITI 


tr Keda 5 K7 1? Unicode (UTF-6) 


图 3-42 ”代码 窗口 


发 现 数据 库 查 询 语句 被 改写 过 ， 在 第 42 行 变量 $query_Rsdb 所 用 的 SQL 语句 是 以 前 介 
绍 过 的 ， 但 在 第 43 行 该 变量 会 放 到 字符 串 的 第 一 个 %s 位 置 处 ， 如 下 : 


$query_limit_Rsdb = sprintf("%s LIMIT 96d, %d", $query_Rsdb, $startRow. Rsdb, $maxRows Rsdb); 
由 上 述 代 码 可 知 ，%s 表示 字符 串 ， 后 面 两 个 %d 表示 数值 ， 所 要 代入 的 值 是 $startRow - 


Rsdb 与 $maxRows_Rsdb。$maxRows_Rsdb 这 个 变量 值 与 前 面 在 重复 区 域 所 选择 的 重复 5 条 
记录 是 同步 的 ， 可 以 看 到 第 34 行 定义 了 这 个 变量 的 值 。 


$maxRows Rsdb = 5; 


可 以 知道 ，Dreamweaver 使 用 了 一 堆 变 量 来 记录 在 图 形 界面 中 所 选择 和 设置 的 值 ， 然 后 
使 用 LIMIT 子 句 来 做 到 一 次 显示 指定 条 数 的 记录 。 


enero 记录 集 分 页 功能 


上 一 市 已 经 浏览 到 记录 集中 的 第 1 一 第 5 条 记录 ， 那 么 剩 下 的 记录 如 何 显 示 ? PIT 
绍 记录 集 分 页 功能 的 实现 方法 。 

(1) 在 页 面 下 方 加 上 1x4 的 表格 ， 接 看 在 时 元 格 中 分 别 输入 [第 一 页 ]、[ 前 一 页 ]、[ 下 
一 页 ]、[ 最 后 一 页 ] 等 文学 。 便 用 鼠标 选取 [第 一 页 ]， 然 后 在 “服务 融 行 为 ”面板 单 击 
“+” 按 钮 ， 从 弹出 的 下 拉 沫 单 中 选择 “记录 集 分 页 ”一 “ 移 至 第 一 页 ”命令 ， 如 图 3-43 
DIES 
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indez.php* Xx 


"RE webconn. php 


| "| — — —] O cue = 


TF 编辑 (EF) ”查看 (VY) 插入 (IT) WER) 格式 (0) r$ (c) 站 点 (53) Aow AEB CH) 


C:\Apache\htdocs\phpweb\indez. php 


+ 一 TM. PHP 


R | 实时 代码 p? FA ANNE RE D O LRE C dE P a. 
I Q co (X) c 地 址 : file:///C |/Apache/htdocs/phpweb/index. php 重复 区 域 


PHPE 动 态 系统 移 至 前 一 页 
移 至 下 一 页 显示 记录 计数 
移 至 最 后 一 页 动态 文本 


EEP 姓名 年 龄 成 绩 插入 记录 


HN 更 新 记录 


143=< 一 | lus ——— m 143» — ———AÀ es 册 | 除 记录 
| nn 
XsLT 转换 


编辑 服务 器 行为 . .. 
| ”新 建 服务 器 行为 . .. 
获取 更 多 服务 器 行为 ... 


CC) 站 点 - phpweb (C. 
a- Connections 
: A add. php 
D del. php 
» detail. php 


<body. ca? <table> <tr> Kta) j nÀ index. php 


o update. php 
格式 F) x ] -E 
& CSS mt) X vx 链接 C) | 目标 (6) 
国 单元 格 KFORU v| aW 16 GAGO[] WRE&ODJ — O 
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3-43 ”设置 为 “ 移 至 第 一 页 ” 


(2) 在 弹出 的 对 话 杠 中， 选择 记录 集 ， 确 认 链 接 所 选 的 范围 ， 如 图 3-44 所 示 。 

(3) 分 别 为 [前 一 页 ]、[ 下 一 页 ]、[ 最 后 一 页 ] 套 用 “ 移 人 至 前 一 页 ”人 “ 移 全 下 一 页 “ 移 全 
最 后 一 页 ”的 服务 占 行 为 。 然 后 按键 盘 上 的 《F12〉 键 ， 在 浏览 器 中 检查 输出 结果 ， 如 图 3-45 
所 示 。 在 页 面 中 试 试 刚刚 完成 的 导航 条 ， 可 以 注意 到 网 址 后 面 加 了 pageNum_Rsdb 与 
totalRows Rsdb 两 个 URL 变量 ， 被 用 来 在 分 页 浏览 时 与 重复 区 域 服务 喜 行为 相 搭 配 。 


A PHP 动 态 系统 — Nicrosoft Internet Explorer 回回 凤 
文件 @) RED SEV REA IAM 才 助 00 r7 
QAR- O- HAA DPsk ux e A- LBL 

地 址 0) &) http: //127.0. 0. 1/phpweb/index. php?pageNum Rsdb-O&totalRows Rsdb-10 v EJ PA HS Qr saaert G 


姓名 
testl 
test2 
test? 
test4 
test5 


[前 一 页 


链接 : | 所 选 范围 :“[ 第 一 页 ] 
pH:  — à ~ 


3-44 设置“ 移 全 第 一 页 ”对 话 框 


也 可 以 在 Dreamweaver 菜单 中 选择 “插入 ”一 “数据 对 象 ” 一 “记录 集 分 页 ”一 “记录 
集 导 航 条 ”命令 ， 来 快速 地 插入 本 范例 中 所 建立 的 记录 集 导 航 条 。 


Dao sp sos 


Dreamweaver+PHP 开 发 基础 


在 页 面 上 方 输入 “ 共 * 和 


第 * 笔 ”， 建 立 起 记录 集 导 航 条 ， 以 便 让 È 
用 户 了 解 有 多 少 页 记录 和 当前 正在 浏览 的 页 码 。 
(1) 将 插入 点 置 


于 “共有 ”和 “笔记 录 ” 之 间 ， 选 择 “服务 器 行为 ”面板 ， 单 击 “+; 
按钮， 从 弹出 的 下 拉 荣 


笔记 录 ， 日 前 查看 第 


单 中 选择 “显示 记录 计数 ”一 “显示 总 记录 数 ”， 然 后 同样 要 选择 记 
录 集 ， 如 图 3-46a、b 所 示 。 
GEO) wo Ww ero el 
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Axim. EHEER E-E CEEPIT: 
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Tiks Name) 


显示 总 记录 数 
[(AIg Qm -eam 6x Wi (IF 
v BJ I1: uU 8 UR 

“QO BWw 


m: -n 


(2) 按 同 样 的 方式 ， 将 插入 点 置 于 相应 位 置 ， 依 序 加 入 “显示 起 始 记 录 编 号 ”及 “显示 
结束 记录 编号 ” 完成 后 页 面 如 图 3-47 所 示 。 
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datail php 
WI 13S es See KI E Yaicede (UTF-Rl 2 index php 
` qwpdate. php 
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3-47 ”加 入 统计 记录 


H 


PHP 


完成 后 ， 当 浏览 该 网 页 时 ， 便 会 出 现 当前 共有 几 笔 记录 ， 以 及 目前 得 看 的 是 第 几 笔 一 第 
儿 笔 的 提示 文字 ， 如 图 3-48 所 示 。 
ETT = Nicroszoft Internet Explorer [- mE 
Tn dA) 查看 的 Ru IAT EOD a 
QE - O RAGGAR: t OG cc 
Hiro) CETME o.o. Lighpwabi index. pho? pagsfun XsdbsD&totilRors, Rsds1Q EIL sm Qu ET | 


PHPZh;S E 


"mem 
姓名 au 


testl 
testz 
test? 
test 
testo 


3-48 ”建立 导航 条 效果 


也 可 以 在 Dreamweaver 菜单 中 选择 “插入 ”一 “数据 对 象 ” 一 “显示 记录 计数 ”一 “ 记 
录 集 导航 状态 ”来 快速 地 插入 本 例 中 所 建立 的 记录 集 导 航 条 。 


So 品 示 区 域 功 能 


在 第 一 外 上 的 [第 一 页 ] 与 [前 一 页 ] 的 文学 链接 是 没有 意义 的 。 下 面 我 们 就 来 处 理 这 个 问 


晤 ， 如 末 不 是 第 一 页 时 ， 显 示 [ 第 一 页 ] 与 [前 一 页 ]; 如 来 不 是 最 后 一 页 时 ， 显 示 [ 下 一 页 ] 与 
[最 后 一 页 ]。 

实现 该 功能 的 步骤 如 下 。 

(1) 选择 [第 一 页 ]， 在 “服务 需 行 为 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 和 单 中 选 
择 “ 显 示 区 域 ” 一 “如 果 不 是 第 一 页 则 显示 ”命令 ， 如 图 3-49a 所 示 。 打 开 “ 如 果 不 是 第 一 
页 则 显示 ”对 话 框 ， 选 择 “ 记 录 集 ”Rsdb， 再 单 击 “确定 ”按钮 ， 如 图 3-49b 所 示 ， 然 后 为 
[前 一 页 ] 也 做 同样 的 设置 ， 即 可 完成 设置 。 
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训 果 不 是 第 一 页 则 显示 
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Dreamweave r+PHP 开 发 基础 


(20 选取 [下 一 页 ] 链 接 文 字 ， 在 “服务 需 行 为 ”面板 中 单 击 “+” 投 钮 ， 从 弹出 的 下 拉 
菜单 中 选择 “显示 区 域 ” 一 “如 末 不 是 最 后 一 页 则 显示 ”命令 ， 如 网 3-50 所 示 。 然 后 为 [最 
后 一 页 ] 也 做 同样 的 设置 。 


Dw | wm | [87] Q cue > 
W 编辑 (EF) 查看 (VY) 插入 (I) EHM ”格式 (0) 命令 (C) 站 点 (3) gow) BH) 


index. php* X C: NApachekht docsSphpwebXindez. php 
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+ 一 文档 类 型 : PHP 
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记录 集 分 页 


如 果 记 录 集 为 空 则 显示 
如 果 记 录 集 不 汶 空 则 显示 显示 记录 计数 
如 果 是 第 一 页 则 显示 HELE 


共有 (Rsdb.TotalRecords) 笔记 录 ， 目 前 查看 第 {Rsdb FirstRecord) 笔 至 第 (加 果 不 是 第 一 页 出 显示。 | anea 


姓名 年 龄 成 绩 E 更 新 记录 
re " 删除 记录 


如 果 符 合 此 条 件 则 明示 fo r ER... | S E UR 

88 — B] : XSLT 转换 
编辑 服务 器 行为 .. 
BRIRA SEN... 

获 职 更 多 服务 器 行为 ... 


件 
日 e 站 点 - phpweb (C... 
E- Connections 
| > add. php 
»| del. php 
cp detail. php 
body. ca? <table> <tr> <td> Ka) 678 x 382» 9 K / 1 $9 Unicode (UTF-8). | D) index.php 


» update. php 
(Omw] toz ~y) 类 | 无 yaBr 三 拭 此 此 标题 0[ —— 
Es moz v ED Cre rin Cavo 县 加 | v 
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3-50 ”设置 “如 朵 不 是 最 后 一 负 则 显示 ” 


G) 完成 后 在 每 个 套用 “显示 区 域 ” 的 “服务 器 行为 ”的 部 分 会 出 现 “如 末 符 合 此 条 件 
则 显示 …” 的 提示 文字 ， 如 图 3-51 所 示 。 
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[Bi — f DE [到 后 一 内]  AnSRERRE— TUR mem Y 
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文件 
区]G@139 人 YY 名 图 | 四 


ft 
日 e 站 点 - phpweb (C... 
g. B Connections 
775 add. php 
del. php 
detail. php 


<body. ca? <table> Ctr? Kta) 100%  ~|678 x 382v 10 K / 1 $9 Unicode (UTF-8). index. php 
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update. php 


3-5] EH “ERKE” AR 


(4) 最 后 按 〈F12》 键 ， 在 浏览 器 中 检查 输出 结果 ， 如 图 3-52 所 示 。 


PHP-* 


QL-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


E | PHP 动 态 系统 一 Nicroso ft Internet Explorer DER) 
TFP AE SEV REAO IAT) 帮助 0) AN 


QAER- O- har yx € 8 Ec 


地 址 0) [Æ] http: //127. 0. 0. 1/phpweb/index. php?pageNun Rsdb-O&totalRows Rsdb-10 v 转 到 ”链接 Qn [ej 


PHP 动 态 系统 


共有 10 笔 记录， 目前 查看 第 1 笔 至 第 5 笔 
姓名 | 年 龄 


test 
test2 
test? 
test4 
test5 


图 3-52 ”设置 “显示 区 域 ” 后 的 效果 


也 可 以 在 Dreamweaver 菜单 中 选择 “插入 ”一 “数据 对 象 ” 一 “记录 集 (Recordset) 分 
页 ”一 “记录 和 集 导 航 条 ”命令 ， 来 快速 地 插入 一 个 分 页 区 域 。 


So 显示 详细 信息 | 


很 多 时 候 ， 并 不 会 开始 就 将 数据 库 所 有 子 段 、 记 录 部 显示 出 来 。 例 如 一 个 新 闻 系 统 ， 在 


首页 上 只 会 显示 新 闻 的 日 期 与 标题 ， 更 详细 的 新 闻 内 容 需 要 选择 标题 进入 到 另 一 个 页 面 才 能 显 
示 。 假 设 显示 新 闻 标 题 的 页 面 是 index.php， 而 显示 详细 狐 闻 内 容 的 网 页 名 称 为 detailphp。 当 
在 index.php 中 点 击 标题 的 链接 后 ， 此 时 该 超级 链接 会 市 看 一 个 参数 到 detail.php， 网 址 类 似 于 
detail.php?ID=1。 多 出 的 ID=1 是 一 个 变量 名 为 ID， 值 为 1 的 URL 参数 。 当 detail.php 收 到 
ID=1 的 URL 参数 后 ， 便 利用 这 个 URL. 参数 在 建立 记录 集 时 敌 选 所 指定 的 新 闻 记 录 ， 并 将 记 
录 详 细 信 息 显 示 在 网 足 上 。 这 样 就 构成 了 一 个 简单 的 新 闻 系 统 染 构 。 要 沛 选 指定 的 记录 可 以 在 
SQL 中 使 用 WHERE FAJ, Æ Dreamweaver 中 有 相应 的 图 形 界 面 可 以 方便 使 用 。 下 面 ， 看 看 
Dreamweaver 是 如 何 运 用 传送 与 接收 URL 参数 来 粒 选 出 指定 的 记录 。 

(1) 使 用 Dreamweaver 创建 一 个 空白 的 detail.php 页 面 并 保存 。 在 index.php 中 选择 要 用 
来 连接 到 话 细 信 息 页 面 的 部 分 《其实 残 是 选择 要 在 哪里 建立 超级 链接 )， 在 本 例 中 选择 序 
号 ， 即 选择 {Rsdb.ID} 动 态 文字 ， 如 图 3-53 所 示 。 
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图 3-53 ”选中 动态 文字 {Rsdb.ID)】 
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(2) 在 下 面 的 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文件 ”图 标 口 ， 如 
图 3-54 所 示 。 
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图 3-54 建立 链接 设置 


(3) 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 detail.php， 如 图 3-55 所 示 。 


选择 文件 名 自 : GG ERE 站 点 根 目录 
ORE 


3h aR SS S8... 


查找 范围 [): | (C) phpweb v € | 2 E? g- 


C) mmServerScripts 


.notes 
[Connections 


hc 


index.php 


XS 00: (detail. php 
MEREM): | 所 有 文件 Gon 


VRL: detail. php 
相对 于 : | PE v | index. php 
在 站 点 定 必 中 更 改 默 让 的 链接 相对 于 


图 3-55 设置 链接 的 文件 
(4) 如 条 仅仅 是 这 样 ， 那 只 会 是 单纯 的 超级 链接 ， 并 没有 附带 URL 参数 。 因 此 ， 要 单 


击 “ 参 数 ” 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 本 例 将 参数 名 称 命名 为 
ID， 在 设置 值 的 时 候 ， 单 击 如 图 3-56 中 上 鼠标 所 指向 的 图 标 。 


图 3-56 设置 参数 


(5) 选择 URL 参数 ID 所 要 带 的 值 ， 因 为 要 的 是 记录 集 ID 字段 的 值 ， 所 以 选择 ID 字段 


如 图 3-57 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 。 


7PHP-^ 


BR: | 无 v 


代码 :| 《<?php echo $row Rsdb[' ID ]; ?> 


3-57 选择 ID 字段 


除了 记录 集 字 段 外 ， 只 要 是 在 “ 绑 定 ”面板 中 所 建立 的 ， 包 括 表 单 变 量 、URL 变量 、 
Session 变量 和 Cookie 变量 等 ， 都 可 以 在 这 里 被 选择 。 

(6) 此 时 ， 可 以 看 到 超级 链接 的 地 址 变 成 detail.php?ID=<?php echo $row_ Rsdb['ID ]; ?>， 
如 图 3-58 所 示 。 
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图 3-58 ”完成 后 的 链接 地 址 


(7) 设置 完成 后 ， es index 页 而 。 可 以 看 到 ， 每 一 条 记录 的 链接 部 市 看 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


URL 参数 DD， 其 值 是 每 条 记录 的 ID. Aul] 3-59 所 示 。 
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PHP 动 态 系统 


共有 10 笔 记录， 目前 查看 第 1 笔 至 第 5 笔 
姓名 年 龄 


testl 
test2 
test? 
test4 
test5 


In [16 |I E a a 


E http: //12T. 0. 0. 1/phpweb/detail. php?ID-1 | B Internet 


图 3-59 ” 单 击 链接 的 属性 显示 
前 而 已 经 完成 了 index.php 中 应 该 完成 的 部 分 ， 下 面 来 看 看 接收 URL 参数 的 detail.php 


第 3 草 Dreamweaver-*PHPZT Æ Z fi 


如 何 用 收 到 的 参数 来 筛选 指定 的 记录 。 
(1) 打开 detail.php 页 面 后 选择 “ 绑 定 ” 面 板 ， 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选 

F WRR AW)” Mme, WME 3-60 rm. f 
(2) 则 会 打开 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 e 
1) 在 “名 称 ”文本 框 中 输入 rsdetail 作为 该 “记录 集 ” 的 名 称 。 rad 
2) 从 “连接 ”下 拉 列 表 框 中 选择 “webconn” 连 接 对 象 。 x 
3) M RR” FAIRER, EREA ERIA websql。 
4) 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 
5) 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID=URL 参数 /ID。 
完成 后 的 设置 如 图 3-61 Brzn 
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: webcorn 


记录 集 ( 查询 ) 


表单 变量 
UL 变量 
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Cookie f 
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:O em O wm. 


图 3-60 选择 “记录 集 (查询 ) ” 图 3-61 设置 “记录 集 ” 对 话 框 


(3) 如 果 想 知道 SQL 语句 ， 可 以 日 击 “ 蜗 级 ”按钮 。 在 “局 级 ”界面 测试 SQL 语句 ， 
如 图 3-62 所 示 。 在 SQL 语句 中 的 colname 是 一 个 变量 ， 知 筛选 的 时 候 有 用 到 变量 ， 
Dreamweaver 就 会 用 这 个 变量 名 称 放 在 SQL 语句 里 。 而 这 个 变量 的 值 会 是 什么 呢 ? Nx I 
"变量 "区 域 中 colname 的 运行 值 的 定义 。 当 网 页 运作 时 ，colname 将 等 于 URL 变量 ID 的 值 
($_GET[TTD'])， 所 以 当 URL 变量 ID 值 不 同 ， 筛 选 出 的 结果 也 不 同 。 


Mirsdetaill 


: |j webconn 


: [SELECT * 
webs 


运行 值 : $ GET[ ID ] 


添加 到 SQL: 


SELECT 


WHERE 


ORDER BY 


* A 图 
zd. ”预存 过 程 


图 3-62 ”高 级 “记录 和 集 ” 对 话 框 


PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(4) 然后 单 击 “ 确 定 ”按钮 ， 完 成 记录 集 建 这 。 记 录 集 建立 完毕 后 ， 可 以 把 各 个 字段 拖 
动 到 页 面 上 相应 的 单元 格 中 ， 如 图 3-63 所 示 。 以 上 详细 页 面 的 制作 融 算 大 功 告 成 。 


m C:NÁpachekhtdocziphpwebidetail.php (EHIML)s 


= 0X 


FHP 动 态 系 统 


T 5 


[Wy 100 lest x eriv 4K/ 1 E Unicode WFE) 
图 3-63 制作 的 详细 页 面 


(5) 完成 后 直接 按 (F12) 键 在 浏览 器 中 打开 detailphp， 发 现 内 容 是 空白 的 ， 如 图 3-64 


所 示 。 这 是 怎么 回 事 呢 ? 因为 在 网 址 后 面 没有 带 看 URL 参数 ， 当 然 记 录 集 里 就 不 会 有 任何 
东西 。 


A 详细 页 面 一 Nicroso ft Internet Explorer 加 回国 
THFT AEE EB) REAO IAM 帮助 0) ax 
QAR- O- [9g Pss ux 0 ee ABL 


地 址 0m) [Æ] http://127.0. 0. 1/phpweb/detail. php 


—5kcmuex MERA dk Q sut E 
PHP 动 态 系统 


编辑 
LE 


图 3-64 “显示 为 空白 


(60 直接 在 网 址 后 加 上 URL 变量 ID， 其 值 可 以 选 1 一 10 的 任何 一 个 值 ， 然 后 按 
(Enter〉 键 ， 网 页 显示 的 结果 如 图 3-65 所 示 。 


A 详细 页 面 一 Microsoft Internet Explorer 加 回国 
WE dB) EEV 收藏 IA) 8500 Ay 
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图 3-65 URL 参数 ID=5 时 的 详细 页 面 
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(7) 在 index.php 中 ， 每 一 笔记 录 的 网 址 都市 有 特定 的 参数 链接 到 detail.php， 如 图 3-66 


所 示 。 


A PHP 动 态 系统 一 Nicrosoft Internet Explorer DER) 
TH AHE EE EA IAM) #80 [7] 


Om- O- NAOR xx 6 0€ 
地 址 0) |Æ] http: //127. 0. 0. 1/phpweb/index. php?pageNum Rsdb-O&totslRows Rsdb-10 v [Eg PA HHE @ snaert [ey 


PHP 动 态 系统 


共有 10 笔 记录 ， 目 前 查看 第 1 笔 至 第 5 笔 
姓名 年 龄 

testl 21 

test2 

test3 

test4 

test5 


I^ | 12s. [Iw i d- : 


Æ] http: //12T. 0.0. 1/phpweb/detail.php?ID-l p pna er 
图 3-66 单 击 首 页 上 的 链接 
(8) 单 击 第 1 个 链接 后 ， 打 开 指 定 记录 的 详细 页 耐 ， 如 图 3-67 所 示 。 


A 详细 页 面 一 Microsoft Internet Explorer 
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3-67 打开 指定 记录 的 详细 页 面 


Section. 


编辑 记录 功能 


前 面 介绍 了 如 何 将 位 于 数据 库 中 的 记录 拖 到 网 页 上 显示 。 本 节 将 介绍 新 增 、 更 新 以 及 删 


除 的 操作 。 


在 数据 表 websql 中 有 4 个 字段 ， 其 中 ID 字段 为 主键 且 附 加 了 auto. increment 属性 ， 


此 在 独 增 记录 时 不 必 考 虑 ID 字段 ， 只 和 需 增 加 3 EB. 


f zr 


实现 的 步骤 如 下 。 
(1) 创建 一 个 空白 的 php 网 页 ， 并 命名 为 add.phpp， 先 添加 一 个 表单 ， 再 插入 一 个 4x2 
表格 ， 键 入 相关 提示 后 依 序 放 上 3 个 文本 字段 、 两 个 按钮 ， 完 成 后 如 图 3-68 HR. 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


HE C: hpachevhtdoesAphpwebvadd php (XHTXL) -H 


PHP 动 态 系统 
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i 山 md 2 d 
RI Q 100$ 4530x229» 1 K / 1# Unicode (UTF-B) — -: 


图 3-68 建立 表单 并 设计 网 页 


当 需 要 新 增 、 更 新 记录 时 ， 网 页 中 需要 有 一 个 表单 且 表 单元 素 必 须 置 于 表单 内 ， 在 单 击 
按钮 后 ， 只 有 在 表单 内 的 元 素 会 被 以 POST 或 GET 的 方式 传递 。Dreamweaver 中 的 新 增 、 更 
新 记录 都 是 将 表单 元 素 的 值 以 POST 的 方式 传递 给 页 面 ， 当 程序 判断 到 指定 字段 〈 新 增 记 录 
F, FRAI MM_insert， 当 使 用 了 “插入 记录 ”服务 器 行为 时 该 字段 将 被 目 动 添加 〉 送出 
了 POST 信息 〈 值 为 窗 体 名 称 )， 便 执行 狐 增 、 更 独 记 录 等 部 分 的 程序 。 

(2) 插入 3 个 文本 字段 ， 并 分 别 选择 各 个 文本 字段 ， 并 在 “属性 ”面板 上 为 其 命名 ， 分 
别 是 姓名 Name, FH Age、 成 绩 Result， 注 意 在 设计 时 要 与 记录 集 字 段 名 称 一 一 对 应 ， 如 
图 3-69 所 示 。 
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图 3-69 命名 文本 域 


说 明 : 
当 表 单元 素 的 命名 与 记录 集 字 段 相 符合 上 时， 在 做 “新 增 记录 ”、“ 更 新 记录 ”时 ， 
Dreamweaver 会 自动 将 表单 元 素 与 记录 集 字 段 相 匹配 。 


Dr eamwea r+PHP 开 发 基础 


第 3 章 


(3) 选择 “服务 器 行为 ”面板 ， 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 沫 单 中 选择 “插入 记 
K” A q^, 如 图 3- 70 所 示 。 


Dw Ce (SIME 
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RULAS ET) 77 Et Sram mm M. d. £EE 
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body) (Ferniiforni) (tabla) (ur) (Li unsuuPEerult [Rh |i) CL 107€ AT dl 2 E 7 1 lnisade (UTF-R) 


| mH cya Osce OSB 
| I. 


e 1 TXANBXST,S[BE.] 
3-70 ”执行 “插入 记录 ”命令 


(4) 打开 “插入 记录 ”对 话 框 ， 设 置 插入 记录 属性 ， 选 择 连 接 为 webconn， 插 入 表格 至 
websql， 这 是 设置 要 将 记录 添加 到 哪 一 个 数据 表 中 。 在 选择 完 数据 表 后 ,“ 列 ”区 域 中 便 会 
出 现 该 数据 表 内 的 所 有 字段 ， 可 以 在 这 里 设置 哪个 数据 表 字 段 要 从 表单 中 的 哪个 元 素 获 取 
值 ， 有 基体 的 设置 如 图 3-71 所 示 。 


: 下 一 个 Eds: ER 
’ name ru TORR. name ERBEN "ue 
age TE ge AENEA — 
"Result! /A z t ARIB Wd 


插入 后 ， 转 到 : index.php 


3-71 设置 “插入 记录 ”对 话 框 


说 明 : 

之 前 将 表单 元 素 的 命名 与 数据 库 字 段 名 称 相 同 ， 所 以 在 建立 “插入 记录 ”时 
Dreamweaver 便 会 自动 将 它们 配对 。 也 可 以 先 选 择 欲 设置 的 字段 ， 由 “ 值 ” 右 方 的 下 拉 式 菜 
单 中 选择 从 哪个 表单 元 素 取得 值 。 然 后 在 “插入 后 ， 转 到 ”的 文本 字段 框 填 上 index.php。 将 
表单 元 素 的 名 称 与 数据 库 内 的 字段 名 称 命名 为 相同 ， 除 了 “插入 记录 ”以 外 , “更 新 记录 ” 
服务 器 行为 也 会 将 相同 名 称 的 数据 列 与 表单 元 素 自动 配对 在 一 起 。 


PHP-*-MvySQL*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(50 设置 完成 后 ， 在 “服务 占 行 为 ”和 面板 的 列表 中 残 会 多 出 一 项 插入 记录 如 图 3-72 所 
示 ， 可 以 双击 该 项 重 靳 进行 “插入 记录 ”的 设置 。 完 成 后 网 页 上 的 表格 会 变 成 浅 绿色 的 撒 ， 
当然 这 并 不 是 表示 有 错误 ， 而 是 表明 该 表单 使 用 了 “服务 器 行为 "。 同 时 ， 在 表单 内 也 目 动 
加 上 了 和 名称 为 MM_insert 的 隐藏 字段 ， 用 来 判断 用 户 是 否 单 击 “提交 ”按钮 大 出 信息 ， 并 是 
侣 执行 “插入 记录 ”部 分 的 程序 代码 。 
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3-72 ”插入 记录 后 的 页 面 效 末 


(60 Aiz (F12) 键 在 浏览 器 中 打开 网 页 ， 输 入 值 如 图 3-73 所 示 ， 并 单 击 “ 提 交 ” 按 
钮 尝试 新 增 一 笔记 录 。 


A 添加 记录 一 Nicrosoft Internet Explorer 
THF AmE EAV 收藏 人 TRI) 5H) 


OFE- O- [92 (5 tek yum 0 A RBL 
地 址 0) Æ] http://127. 0. 0. 1/phpweb/add. php < 输入 关键 词 搜索 v Gra H @ snai B 
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3-73 ”输入 记录 数据 


CI) 单 击 “提交 ”按钮 后 ， 网 址 将 从 add.php 转 全 index.php。 点 击 网 页 下 方 的 分 页 导航 
条 的 [最 后 一 页 ] 链 接 ， 便 可 以 看 到 刚才 新 增 的 记录 ， 如 图 3-74 Pm. 


rig) 48g) $E) kR T HR 


vu © dac Pe kar 各 | 全- $0 € 


PHPZAISA SE 


共有 11 笔 记录， 目前 查看 第 11 笔 至 第 11 笔 
姓名 Fi? 


tegl! 25 


3-74 增加 记录 后 的 效果 

程序 说 明 : 

简单 地 来 看 看 这 部 分 的 程序 代码 是 怎样 的 。 表 单 的 “动作 ”为 <?php echo $editForm 
Action; ?> (如 图 3-75 所 示 )， 在 单 击 按钮 后 网 页 是 将 信息 以 POST 的 方式 送 给 自己 ， 所 以 先 记 
住 这 个 变量 后 切换 至 “代码 ”视图 。 在 “代码 ”视图 中 可 以 看 到 $editFormAction 变量 的 值 如 图 
3-75 所 示 ，$ SERVER 是 预定 义 变 量 的 一 种 ， 用 以 提供 服务 器 的 相关 信息 ; 而 
$_SERVER[PHP_SELE] 便 是 返回 该 网 页 的 文件 名 称 。 所 以 表单 的 "动作 "为 <?php echo 
$editFormAction; ?> 就 意味 着 ， 将 表单 数据 以 POST 方式 传递 给 自身 。 
性 


TE AE [Pohe echo jeüiomAetim; ?> |O BÉRD| č ? 
J 


3-75 ”表单 动作 参数 


接着 看 到 被 自动 添加 的 隐藏 字段 MM. _insert， 其 值 是 form1， 与 所 在 位 置 的 表单 名 称 一 
致 。 代 码 的 窗口 如 图 3-76 所 示 。 


DW | em | PT) Ocu COED 


XHO) mam NO) MAD MOOD XO eeo MAGO WD 帮助 00 
MOERS (foral, wabecsm, eua) 


NE (edicFormAccion = $ SERVER('PHP SELF); 
if (1s532ec(6 SEPVER['QUERY STRING'])]) ( 
a "9" , htalentities(4 SERVER['QUERY STRIWOC']); 


if ((issec($ POST "W insert"])) ee (6 FOST("IM insert”) sa "formi"]) ( 
(inserrSO0L « sprintf("INSERT INTO websql (name, age, '"Remult ) VALUES (ta, ts, 
ka)", 
Ger3QLYslue3tring(i FOST['name'], ^"text^], 
eet3QLValueString($ FOST['age'], "int"), 
CGec$SQLValueS$tring(é POST('Pesult'], "text"))? 


lel" 2€ «otc s 


M 


mysql select db(fdatabase webconn, fvebconn); meld, — 
£Resultl * mysql query(s;insert2JO0L, évebconn) or die([mysql, erroE()); | m GLG 
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图 3-76 ”代码 窗口 


PHP 


核心 的 代码 说 明 如 下 : 


if ((üsset($ POST["MM. insert"])) && ($ POST["MM insert"] == "form1")) { 


/判断 表单 变量 $_ POST['MM_insert] 是 否 被 设置 ， 且 值 是 否 等 于 forml1。 如 果 是 ， 则 执行 下 面 的 插 


入 记录 动作 。 
$insertSQL = Sprintf("INSERT INTO websql (Name, Age, "Result ) VALUES (96s, 96s, 96s)", 
/定义 了 SQL 语句 。 
GetSQLValueString($_POST['Name'], "text"), 
GetSQLValueString($_POST['Age'], "int"), 
GetSQLValueString($ POST['Result'], "text")); 
/ 取 值 表单 的 变量 。 


mysql select db($database webconn, $webconn); 
$Resultl = mysql query(SinsertSQL, $webconn) or die(mysgl error()); 
/连接 数据 库 执 行 SQL 语句 。 
$insertGoTo = "index.php"; 
/设置 了 在 "插入 记录 "后 要 跳 转 的 文件 index.php， 它 被 存储 在 变量 $insertGoTo。 


更 新 记录 功能 是 指 将 数据 库 中 的 旧 数 据 根 据 需要 进行 更 新 的 操作 。 这 里 会 用 前 面 已 经 使 
用 到 的 detail.php 文件 。 

更 新 记录 功能 的 操作 步骤 如 下 。 

(1) 打开 detail.php 网 页 后 ， 选 中 “更 新 ” 如 图 3-77 所 示 。 
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3-77 选择 链接 文字 


(2) 在 “属性 ”面板 中 ， 单 击 如 图 3-78 所 示 的 “浏览 文件 ”图 标 ， 为 其 建立 附带 URL 
参数 的 超级 链接 。 


(QL*-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 
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(3) 输入 用 来 更 新 记录 使 用 的 update.php HA, RER BAO HL JJESGENDAE 
为 ID， 值 是 rsdetail 记录 集 ID FRE URL 参数 ， 如 图 3-79 所 示 。 
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图 3-79 ”选择 文件 并 设置 参数 


(4) 单 击 “ 人 确定” 按钮 ， 完 成 后 的 链接 地 址 : 
update.php?ID=<?php echo $row. rsdetail['ID']; ?>// 传 递 ID 到 update.php 页 面 ， 如 图 3-80 


所 示 。 
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3-80 传递 ID 至 update.php 


(5) 创建 update.php 文件 。 开 始 的 操作 与 乙 前 在 制作 记录 详情 页 面 detail.php 时 相同 ， 
部 是 利用 接收 到 的 URL. SAINE WRK. Æ ERTA” WP, Ari +” H, M 
RERI PARERE RR AAW)” MS, WE 3-81 所 示 。 
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3-81 选择 “记录 集 (查询 ) ” 


(6) 打开 “记录 和 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 rsupdate 作为 该 “记录 集 ” 的 名 称 

20 从 “连接 ”下 拉 列 表 框 中 选择 “webconn” 连 接 对 象 。 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 和 象 为 websql。 
4) 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

5) 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID=URL 参数 / ID。 
完成 后 的 设置 如 图 3-82 所 示 。 


3-82 ”设置 “记录 和 集 ” 对 话 框 


(7) 将 页 面 中 应 该 有 的 表单 、 文 本 字段 、 按 钮 设 年 完成， 在 “ 绑 定 ”面板 中 将 记录 集 内 
的 字段 拖 动 至 页 面 上 各 对 应 的 文本 字段 中 ， 如 图 3-83 所 示 。 
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图 3-83 HEFE 
(8) HF ID 是 主键 ， 不 能 随便 变更 主键 的 值 ， 因 此 选择 ID 部 分 的 文本 字段 ， 单 击 忌 标 
右键 ， 从 弹出 的 快捷 染 单 中 选择 “编辑 标签 (input)” 命 令 ， 如 图 3-84 所 示 。 
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图 3-84 设置 “编辑 标签 ”命令 
(9) Æ WM AP, WE RR” RAH, WK 3-85 所 示 。 通 过 这 样 的 设置 ， 这 
个 字段 便 不 能 被 用 户 修改 。 
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3-85 设置 为 “只 谈 ” 属 性 


'PHP- 


Dw 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(100. 然后 再 单 击 “ 服 务 器 行为 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “更 
新 记录 ”命令 ， 如 图 3-86 所 示 。 
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3-86 执行 “更 新 记录 ”命令 


C1) 打开 “更 新 记录 ”对 话 框 ， 设 置 更 新 记录 的 参数 。 选 择 “ 连 接 ”webconn 后 ， 
个 表单 元 素 与 字段 都 会 目 动 匹配 好 ， 只 需 在 “在 更 狐 后 ， 转 到 ”输入 框 填 上 index.php. JU 
图 3-87 所 示 。 
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(B: | FORM. ID 
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index.php 


3-87 ”设置 “更 新 记录 ”参数 


(12) 蛙 击 “确定 ”按钮 ， 完 成 后 页 面 的 表格 同样 会 被 侠 上 浅 绿色 的 压 ， 而 表单 中 也 会 
多 出 一 个 隐藏 字段 ， 名 称 为 MM_update， 值 与 表单 名 相同 ， 如 图 3-88 所 示 。 


(13) 最 后 在 浏览 器 中 打开 index.php， 选 择 最 后 一 笔记 录 到 详情 页 面 detail.php， 然 后 在 
详情 页 面 选择 “更 新 ”链接 ， 如 网 3-89 所 示 。 
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图 3-88 ”完成 的 页 面 效 果 
3 详细 页 面 — Microsoft Internet Explorer BR) 
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(14) 在 update.php 中 可 以 修改 姓名 、 年 龄 与 成 绩 的 字段 值 ， 而 ID 文本 子 段 是 不 能 被 修 
改 的 。 更 改 完成 后 ， 单 击 “ 更 新 ”按钮 ， 如 图 3-90 Br. 
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3-90 ”修改 数据 


"PHP 


返回 到 index.php， 检 和 碍 该 笔记 录 是 否 被 正确 更 新 ， 如 图 3-91 所 示 。 
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图 3-91 完成 更 新 的 功能 页 面 


这 部 分 的 程序 代码 与 插入 记录 基本 相同 ， 关 别 只 在 于 隐藏 字段 的 名 称 不 同 ， 使 用 的 是 
UPDATE 语句 。 


EC E 删除 记录 功能 


删除 记录 功能 是 指 将 数据 从 数据 库 中 删除 ， 使 用 “服务 器 行为 ”中 的 “删除 记录 ”命令 
即 可 以 实现 。 

有 具体 的 实现 步骤 如 下 。 

(10 HERR wA URL 参数 转 到 删除 页 面 delphp。 首 先 在 detail.php 中 选中 “ 删 
ER". 在 “属性 ”面板 中 建立 链接 ， 如 图 3-92 rn. 
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3-92 设置 “删除 ”链接 


(2) 因为 删除 记录 还 是 依据 主键 的 ID 子 段 ， 故 选择 删除 记录 所 用 文件 del.php， 并 附 市 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


| | Dreamweave r+PHP 开 发 基础 


URL 参数 ， 其 名 称 为 ID， 值 为 rsdetail 记录 集 的 ID 字段 值 ， 如 图 3-93 所 示 。 


WeEGDUREB: XR 站 点 根 目录 
〇 数据 源 


站 点 和 服务 器 . . 


文件 名 0 ; 
TFW (T): | 所 有 文件 ox) 的 


w Ce 
相对 于 : detail. php 
在 站 点 定 必 中 更 改 默 认 的 链接 相对 于 


3-93 ”设置 传递 的 参数 属性 


(3) 单 击 “ 确 定 ” 按 钮 ， 这 样 就 完成 了 detail.php 的 修改 工作 ， 接 下 来 开始 修改 
del.php。 创 建 del.php 文件 ， 在 “ 绑 定 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 沫 单 中 选择 
“记录 集 (查询 )” 命 令 ， 如 图 3-94 所 示 。 
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图 3-94 ”选择 “记录 集 (查询 ) ”命令 


(4) 打开 “记录 和 集 ” 对 话 杠 ， 在 该 对 话 框 中 进行 如 下 设置 。 
D 在 “名 称 ” 文 本 框 中 输入 rsdel 作为 该 “记录 集 ” 的 名 称 。 
20 从 “连接 ”下 拉 列 表 框 中 选择 webconn 连接 对 象 。 


PHP+MySQL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 websql。 
4) 在 “ 列 ” 单 选 按 钮 组 中 选择 “全 部 ” 单 选 按钮 。 

5) 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID=URL 参数 /ID。 
完成 后 的 设置 如 图 3-95 所 示 。 


到 3-95 设置 “记录 集 ” 对 话 框 
(5) 将 各 个 记录 集 字 段 拖 动 到 页 面 中 所 对 应 的 文本 框 后 ， 将 “删除 ”按钮 命名 为 Del, 
接着 在 “服务 器 行为 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “删除 记录 ” 命 
令 ， 如 图 3-96 所 示 。 
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图 3-96 选择 “删除 记录 ”命令 
(6) 在 弹出 的 “删除 记录 ”对 话 框 中 ， 进 行 如 图 3-97 所 示 的 设置 。 


首先 检查 是 否 已 定 只 变量 ; 


: |websql 
:|ID v 数值 
: [URL 参数 ~| [ID 


册 除 后 ， 转 到 : index.php 


3-97 设置 “删除 记录 ”对 话 框 


“主键 列 ” 与 “主键 值 ”所 设置 的 是 删除 记录 的 依据 ， 这 里 的 依据 是 指 在 DELETEFORM 
数据 表 WHERE 条 件 里 的 条 件 ， 假 设 条 件 是 WHERE ID=11， 相 应 地 ， 可 以 看 成 WHERE 主键 
列 = 主 键 值 。 在 这 里 并 不 一 定 要 选择 数据 库 中 的 主键 来 当做 主 索引 键 字段 。 

C7) 单 击 “确定 ”按钮 完成 设置 。 

至 此 ， 己 经 学 习 了 最 基本 的 Dreamweaver 内 置 服务 右 行 为 ， 并 有 日 了 解 了 其 源 程序 代码 的 
意义 。 在 后 面 各 章节 中 的 模版 系统 ， 如 用 户 管理 系统 、 留 言 管理 系统 、 新 闻 管 理 系统 等 ， 都 
将 用 到 这 些 操作 。 
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4 草 ” ”用户 官 理 系统 开发 


用 户 管 理 系统 是 PHP 网 站 开发 应 用 中 秆 向 使 用 的 一 种 技术 。 一 个 典型 的 用 户 管理 系 
统 ， 一 般 应 该 有 用 户 注册 功能 、 资 料 修 改 功能 、 取 回 密码 功能 ， 以 及 用 户 注销 喘 份 等 功能 。 
本 章 将 前 面 介 绍 的 知识 加 以 灵活 应 用 ， 在 实例 中 主要 用 到 创建 数据 库 和 数据 库 表 、 建 立 数 据 
源 连 接 、 建 立 记 录 集 、 创 建 各 种 动态 页 和 面 、 添 加 重复 区 域 来 显示 多 条 记录 、 页 面 乙 间 传 递 信 
县 、 创 建 寻 航 条 、 隐 藏 导航 条 连接 等 技巧 和 方法 。 
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(7 用 户 管 理 系 统 网 站 结构 的 搭建 

O 创建 数据 库 和 数据 库 表 

(— 建立 数据 源 连 接 

O 掌握 用 户 管 理 系 统 中 页 面 之 间 信 息 传 递 的 技巧 和 方法 
(7 用 户 管 理 系 统 常 用 功能 的 设计 与 实现 


*X45 QGRLGEPEUEZEZ 
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在 制作 网 站 的 时 候 ， 一 般 部 要 在 制作 之 前 设计 好 网 站 各 个 页 面 之 间 的 链接 关系 ， 绘 制 出 
系统 脉络 图 ， 以 便 后 面 整个 系统 的 开发 与 制作 。 


系统 结构 设计 


“用 户 管理 系统 ”的 系统 结构 如 图 4-1 所 示 。 本 系统 主要 的 结构 分 成 用 户 登 录 蛋 块 与 找 
加 密码 修改 资料 模块 两 个 部 分 ， 其 中 index.php 是 这 个 网 站 的 首页 。 


用 户 管理 系统 
用 户 登 录 模 块 找 回 密码 修改 资料 模块 


loginfail.php welcome.php 
lostpassword.php userupdate.php 


新 用 户 注册 页 面 


register.php showquestion.php userupdateok.php 
regfail.php regok.php showpassword.php logoot.php 


图 4-1 系统 结构 图 


在 本 地 计算 机 设置 站 点 服务 器 ， 在 Dreamweaver CS 5.5 的 网 站 环境 除了 按 (F12〉 键 来 
浏览 网 页 之 外 ， 还 可 以 在 正 浏 览 器 输入 “http:/localhostymembervindex.php” 来 打开 用 户 系统 
的 首页 index.php， 其 中 member 为 站 点 名 。 


页 面 规划 设计 


用 户 管理 系统 的 主要 结构 分 为 用 户 登 录 和 找 回 密码 修改 资料 两 个 部 分 ， 整 个 系统 共有 
12 个 页 面 ， 各 个 页 面 的 名 称 和 对 应 的 文件 名 、 功 能 如 表 4-1 所 示 。 


表 4-1 用 户 管理 系统 网 页 设计 表 


页 面 名 称 E 能 

index.php 实现 用 户 管 理 系 统 登 录 功 能 的 页 面 
welcome.php 用 户 登 录 成 功 后 显示 的 页 面 
loginfail.php 用 户 登 录 失 败 后 显示 的 页 面 
register.php 狐 用 户 用 来 注册 输入 个 人 信息 的 页 面 


regok.php 狐 用 户 注册 成 功 后 显示 的 页 面 


PHP+ QL--Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(BE) 
页 面 名 称 功 能 
regfail.php 狐 用 户 注 册 失 败 后 显示 的 页 面 
lostpassword.php 丢失 密码 后 进行 密码 查询 使 用 的 页 面 
showquestion.php 伍 询 密码 时 输入 提示 问题 的 页 面 
showpassword.php 答对 查询 密码 问题 后 显示 的 页 面 
userupdate.php 修改 用 户 资 料 的 页 面 
userupdateok.php 成 功 更 新 用 户 资料 后 显示 的 页 面 
logoot.php 退出 用 户 系 统 的 页 面 


创建 用 户 数据 库 


通过 对 用 户 管理 系统 的 功能 分 析 发 现 ， 这 个 数据 库 应 该 包括 注册 的 用 户 名 、 注 册 密 码 以 
及 一 些 个 人 信息 ， 如 性 别 、 年 龄 、E-mail、 电 话 等 。 所 以 在 数据 库 中 必须 包含 一 个 可 容纳 上 
述 信息 的 表 ， 称 之 为 “用 户 信息 表 ” 将 数据 库 命 v member， 接 下 来 要 在 MySQL 建立 网 
站 数据 库 作 为 得 询 、 痢 增 、 修 改 与 删除 任何 数据 的 后 站 文 持 。 制 作 步 又 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL", YEA MySQL 数据 库 的 管理 面 
板 ， 如 图 4-2 所 示 。 

(2) Hat LH) Create 增加， 按钮， 并 在 打开 的 下 拉 有 末 单 中 侍 击 选择 “Database 
(数据 库 )” 命 令 ， 如 图 4-3 Drm. 


EüL Nannger 2007 for ESL = 6 Ea 
Diten MN; Toon amem Pun Lem indo Hee 
E HON: 1 Ea zm B 5 i TRANNE TA 
Eg em Started 
ie c ale rere He 


T" hianage existing databasn(s) 


Database Tools " 
" WEW 
B Execute E script | 
QE Manage users Eu Procedure 
Help and Support | A 
Function 
i) Sg Manager 2007 halp syste | 
mr J Scheduled Event 
E77 m Irnerriet Resources LIDIF 
E fj SQL Manager 2007 home page d. Support Certe | 
LH DUAL Monge SED! enc liis: docurnentahion Ll CLA Non SEIL, FAL 
而 Favorite Gluery 
图 4-2 打开 MYSQL 数据 库 K|4-3 单 击 选择 “DataBase” 


(3) 打开 “Create DataBase Wizard (建立 数据 库 问 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
“member”， 再 单 击 Next( 下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 ， 如 图 4-4 所 示 。 

(4) 设置 MySQL 数据 库 的 属性 设置 如 表 4-2 所 示 ， 连 接 设 置 如 图 4-5 所 示 ， 然 后 再 单 
ii Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 


第 4 章 


Create Database Wizard 


Create Database 


Specify the name for a new database 


Welcome ta the create Database Wizard! 
This wizard allows vou to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SaL statement for creating the database and execute it 
on Mysia server. 


LONE 


Register after creating 


Database name 


图 4-4 输入 数据 库 的 名 称 member 


表 4-2 数据 库 属性 设置 


User name root 
Password admin 


Create Database Wizard 
Create Database 


Set connection properes for a new database 


localhost v Port 3308 —7 
User name ragt 


senes [OOO [Bem setna 
awn OOOO 


[ ]use tunneling 


Host name 


Password 


Tunneling 


SSH tunneling HTTP tunneling 


EHE INN 


K|4-5 连接 设置 


用 户 管理 系统 开发 


(50 打开 新 建 数据 库 的 SQL 语句 所 示 ， 创 建 数据 库 member， 百 接 单 击 Next (下 一 步 ) 


按钮 ， 如 图 4-6 所 示 。 


动态 网 站 建设 从 入 门 到 精通 


Create Database Wizard 


Create Database 


Hesult SQL statement. Click the Finish button to create a new database. 


l soL 


— Manager 
—— tor MySQL 


Result SoL statement:: 
CREATE DATABASE `rmember'`; 


Click "Finish" ta create the databaze. 


Cancel 


4-6 完成 设置 


(6) 单 击 Finish〈 完 成 ) 按钮 ， 打 开 注 册 数 据 库 的 设置 画面 ， 选 择 utf8 FIR, AP 
文 版 的 GB2312 版 ， 其 他 的 则 保持 默认 值 ， 如 图 4-7 所 示 。 


Database Registration Info 


$^ Connection 


4l | Display Options 
(= Directories 


e SSH Tunneling 
HTTP Tunneling 
HH Data Options 


Connection 


Host name 
User name 
Passwword 


Database name 
Database alias 


Client charset 


Eont charset 


4-7 ”选择 简体 中 文 版 


CI) Hah OK (确认) 按钮， 完成 数据 库 member 的 新 增 工 作 。 

数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 分 别 是 管理 员 
数据 admins 及 用 户 数据 member。 建 立 数据 表 后 ， 接 着 再 单 击 左边 的 “Connect to Database 
(连接 数据 库 )” 图 标 站 将 其 连接 上 。 这 两 张 数据 表 的 字段 结构 内 容 说 明 如 下 。 


C1) 建立 数据 库 member 后 ， 用 鼠标 右键 单 击 选择 Table 
(表格 ) 选项 ， 在 打开 的 豆单 中 单 击 选择 “New Table Cr 
格 )” 命 令 ， 如 图 4-8 所 示 。 

(2) 数据 库 右 方 画 面 会 出 现 新 建 数 据 表 (Table) 的 设置 区 
hk, 含有 “Table (表格 )”“Fields CA", “DDL (驱动 )”3 
个 选项 卡 。 先 在 “Table (表格 )” 中 输入 数据 表 名 member, Al 
图 4-9 所 示 。 

(3) 然后 再 切换 到 “Fields (内 容 )” 选 项 卡 中 ， 输 入 数据 
域名 以 及 设置 数据 域 位 的 相关 数据 ， 如 图 4-10 所 示 。 


£ Table — [member] - [member on localhost] 


Object ^ | Properties | Fields | Indices | Triggers | Data | Dependencies | DDL 
| [3 member on localhost [n v Table name member 


| EF member v | Storage Options 


Storage engine MyISAM 
cn E e Row format DYNAMIC 
[a] Refresh | Min. rows 
学 Compile 图 = : Max. rows 
Qs Grants on table : 


Auto increment value 


DE - Average row length 
@) Show SQL help 了 


d Table Editor options 
回 Restore default size 


*»&»*€»«»/«» 


Size for index key blocks 
[C] Check sum [C] Delay key write 
[ ]Pack keys Temporary 


Tools 


Character Sets |File Options | Merge Table Options | Federated Table Options 


E | Truncate table 
Character set utf 


( Collation utf8. bin 
4-9 输入 数据 表 名 member 


£ Table — [member] - [member on localhost] 


1) New Table... Chrl-M 


Refresh Tables Es 


Database Registration Info... 


4j New Tab from Here... 
Rename Current T ab... 
Delete Current T ab 
Find Item... Ctrl+F 


图 4-8 开始 建 数据 表 


Gexum O O 


DEK) 


Object Al | Properties | Fields | indices | Triggers | Data | Dependencies | DDL | 


Field Name Field Type Size ^ Precision Not Null Default 


Comment 


| [3 member on localhost [n v 


go O NEGER  " 0 Null 


| 国 member v | 


username VARCHAR 20 Null 


password [VARCHAR 20 Null 


- 


question VARCHAR 50 Null 


E Refresh answer VARCHAR 50 Null 


mammam 


学 Compie truename |VARCHAR — (50 Null 


[| Bis Grants on table sex VARCHAR Null 


address VARCHAR Null 


éa Print 


@) Show SQL help tel VARCHAR 


Null 


QQ [VARCHAR Null 


dh Table Editor options 


email VARCHAR Null 


cO ococococoooocoi'ioco 


回 Restore default size 


Null 


II L3 E ETE EST 


authority CHAR 


| 
URCENA AAAA] 
wa a a a a e aa a a a e e aa a a 


Tools 


E Truncate table 


Sg Add new field 
E4 Edit selected field 
Eg Drop selected field(s) 


图 4-10 设置 数据 库 


各 字段 如 表 4-3 所 示 。 这 个 数据 表 主 要 是 记录 每 个 用 户 的 基本 数据 、 加 入 的 时 间 ， 以 及 


登入 的 账号 与 密 公 。 


PHP+ 


表 4-3 member 数据 表 


字段 名 称 TRES TRAG 


ID 1 


3 


N 
© 


username varchar 


N 
© 


password varchar 


cA 
© 


question varchar 


LA 
© 


answer varchar 


truename varchar 


© 


sex varchar 


CA 
© 


address varchar 


cA 
© 


tel varchar 


QQ varchar 


cA | N 
© | © 


email varchar 


[e] 
= 
= 


— N — 


authority 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


HET 
用 户 编号 
用 户 账号 
用 户 密码 

找 回 密 码 提示 

答案 
真实 姓名 
姓 别 
m 


也 可 以 直接 在 DOS 的 MySQL 输入 管理 状态 下 直接 创建 数据 表 ， 实 现 的 命令 如 下 : 


CREATE TABLE member ( 
"ID? int(11) NOT NULL AUTO INCREMENT, 
"username" varchar(20) COLLATE utf8 bin NOT NULL, 
"password: varchar(20) COLLATE utf8 bin NOT NULL, 
"question" varchar(50) COLLATE utf8 bin NOT NULL, 
"answer varchar(50) COLLATE utf8 bin NOT NULL, 
‘truename varchar(50) COLLATE utf8 bin NOT NULL, 
“sex varchar(10) COLLATE utf8 bin NOT NULL, 
"address varchar(50) COLLATE utf8 bin DEFAULT NULL, 
"tel varchar(50) COLLATE utf8 bin DEFAULT NULL, 
‘QQ varchar(20) COLLATE utf8 bin DEFAULT NULL, 
"email varchar(50) COLLATE utf8 bin DEFAULT NULL, 
"authority, char(1) COLLATE utf8 bin NOT NULL, 
PRIMARY KEY CID) 


) ENGINE=MyISAM AUTO INCREMENT-2 DEFAULT CHARSET-utf8 COLLATE-utf8 bin; 


定义 member 丫 点 


在 Dreamweaver CS 5.5 中 创建 一 个 “用 户 管 理 系 统 ” 网 站 站 点 members， 由 于 这 是 PHP 


数据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 4-4 所 示 。 


表 4-4 站 点 设置 的 基本 参数 
站 点 名 称 members 


本 机 根 目 录 C:\Apache\htdocs\members 
测试 服务 器 C:\Apache\htdocs\ 


EY E 用 户 管理 系统 开发 


CBE) 
网 站 测试 地 址 http;//localhost/members/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All Users\Application DataMySQL\MySQL Server 5.5\data\member 
管理 账号 / 密码 root / admin > 
数据 库 名 称 member 


创建 members 站 点 具体 操作 步骤 如 下 。 
(1) 首先 在 CAMApacheWMtdocs 路 径 下 建立 members 文件 夹 ， 如 图 4-11 所 示 ， 本 章 所 有 


建立 的 网 页 文件 都 将 放 在 该 文件 夹 下 。 
mwC- Apachevhtdocs RD) 
ar 


WHFP Aa EOD 收藏 以 ) IAM BH) 
QEB- Od ORR (xtX | 回 - 
地 址 部 ) [- C: SApachekhtdocs v 转 到 


文件 和 文件 任务 ”人间 A Wb - shop 
1 KB 
wj Eder 
PE DE: | 
D ext P 
Q srtxsscema 
pg 共享 此 文件 到 
以 电子 邮件 形式 发送 
该 文件 来 内 的 六 御 
X 出 除 这 个 文件 到 


[^ Apache 

ELI 
gi 共享 文档 
q 我 的 电脑 
G 网 上 邻居 


EE 1 THR PE i 


4-11 建立 站 点 文件 夹 members 


(2) 运行 Dreamweaver CS $.$， 和 选择 菜单 栏 中 的 “站 
点 ”一 “管理 站 点 ”人 命令， 打开“ 管理 站 点 ”对 话 框 ， 如 


图 4-12 所 示 。 
(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 em 

定义 的 站 点 。 单 击 右边 的 “新 建 ” 按 钮 ， 打 开 “ 站 点 设置 对 

象 ” 对 话 框 ， 进 行 如 下 参数 设置 : 
“让 点 名 称 ”: members. 


“本 地 站 点 文件 夹 ” C:\Apache\htdocs\members\。 

如 图 4-13 所 示 。 

(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [ 主 |， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 4-14 所 示 的 参数 设置 。 

“服务 占 名 称 ”: members. 


4-12 “管理 站 点 ”对 话 框 


PHP+ QL-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


“连接 方法 ” 本 地 /网 络 。 
“服务 器 文件 夹 ” C:\Apache\htdocs\。 
“Web URL”: http://localhost/。 


WERKANS. members 
Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweaver 


站 点 通常 包含 两 个 部 分 ; 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 发 布 到 web 上 的 服务 器 上 的 远程 文件 来 。 


您 可 以 在 此 处 当 Dreamweaver 站 点 选择 本 地 廊 件 夹 和 名 称 。 
站 点 名 称 ; 
本 地 站 点 次 件 夹 ; | Capache\htdocstmembers 一 


图 4-13 新 建站 扣 参 数 设置 


站 点 设置 对 甸 members 


[mE = EX i] 
服务 器 名 称 
服务 器 文件 | - 
webun 


取消 


图 4-14 设置 “基本 ”选项 卡 


(5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 步 
信息 ” 复 选 按钮 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL， 表 示 是 使 用 PHP FF 
发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 4-15 所 示 。 

(6) 单 击 “ 保 在 ”按钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 按钮 ， 
如 图 4-16 所 示 。 


用 户 管 理 系 统 开 发 


设置 来 自 
版 本 控制 
^» EE [V 维护 同步 信息 
口 保存 时 自动 将 文件 上 传 到 服务 器 
口 自用 文件 职 出 功能 
区 打开 文件 之 前 职 出 
取出 名 称 : | | 


电子 邮件 地 址 8000000000000 | 


E EI Web JEX 


4-15 设置 “局 级 ”选项 卡 


站 点 设置 对 锣 members 
mu USE 
您 将 在 此 位 置 选择 承载 Web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 


Internet 服务 提供 商 (ISP) 或 web 管理 员 。 


注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步骤 。 如 果 要 连接 到 web 并 发 
布 页 面 ， 您 只 需 定 以 一 个 远程 服务 器 即 可 。 


| 连接 | 远程 EUN 
members CifApache/htdocs ZH Mw M 


4-16 WE “Ri” Z% 


单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 
才 所 设置 的 站 点 members。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 以 上 束 完 成 了 
Dreamweaver CS 5.5 测试 用 户 管 理 系 统 网 页 的 网 站 环境 设置 。 


S 设置 数据 库 连 接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系 统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 
连接 设置 如 下 。 


PHP+ QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(1) 将 光盘 中 设计 的 本 半 静 态 文 件 复制 到 站 点 文件 来 下 ， 打 开 index.php， 如 图 4-17 
pi 


Dw | eB v| O) Oow COES 
XO) 编辑 (E) 查看 (Y) 插入 (D 修改 M) 格式 (0) 命令 (C) 站 点 (S) IQ ERCH) 


index.php X C: \Apache\htdocs\member\indez. php 3 


€ EP nymember. php 
; niin 本 地 视图 vw 


i Go C A Wii: |£i1e:///C |/Apache/htdocs/member/index.p 


c 
由 -onsia tions 


images 
[is = © index.php 
T5 loginfail. php 


) logoot. php 


| 
[ e» lestpassword... 
de es En 
E»] es c regfail.php 
/oo E 3B m register.php 


5 regok php 
À showpassword... 
v» showquestion... 
»  wuserupdate.php 
特别 bem 5 userupdateok... 
= welcome. ph 
j| |, TRIS: SEEL i00, SERES, I4 TE 
METRAR FEH, 外 观 美 等 特点 。 
Eftr: 旺 2480 
会 员 价 : ¥ 2180 


EX 
| E 
861 x 365v» 111 K / 3 f? Unicode (UTF-8) 


C THESES 
v 


E css ID(I) | 无 


mmt... 列表 项 目 


4-17 打开 index.php 


(2) 单 击 选择 沫 单 栏 上 的 “窗口 ”一 “数据 库 ” 命 

， 打 开 “ 数 据 库 ” 和 面板 。 在 “数据 库 ” 和 面板 上 ， 单 击 选 
M “+” 图 标 ， 并 在 打开 的 来 单 中 选择 “MySQL 连接 ” 
选项 ， 如 图 4-18 所 示 。 

(3) Æ “MySQL 连接 ”对 话 框 中 ， 输 入 的 “连接 名 
称 ” 为 mymember, “MySQL 服务 器 ”名 为 localhost, 
“HPZ” XÑ root， 密 人 码 为 admin 如 图 4-19a 所 示 。 选 择 
所 要 建立 连接 的 数据 库 名 称 ， 可 以 单 击 “ 选 取 ” 按 钮 , 浏 06018 W MySQL i 
w MySQL 服务 右上 的 所 有 数据 库 。 选 择 刚 导入 的 范例 数据 库 member， 其 体 的 设置 内 容 如 
图 4-19b 所 示 。 


连接 名 称 : mymember [db shop - 
information schema 
MySQL 服 劳 器 : localhost 


7 mysql 
用 户 名 : root i performance schema 


IJA: Goeekek 


数据 库 : member 


4-19 设置 MySQL 连接 参数 


4s 用 户 管理 系统 开发 


(4) 单 击 “ 测 试 ” 按 钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 果 正 确 ， 则 会 出 现 
一 个 如 图 4-20 所 示 的 消息 框 ， 这 表示 数据 库 连 接 设 置 成 功 。 

单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 
如 图 4-21 所 示 。 


HEF | Sp | 服务 器 行为 | E 
* 一 TEŽU: PH C 


E (3 mymember 
日 脚本 编制 


am membe 
m, address (varchar 50) 
l— m, answer (varchar 50 必需 的 ) 
NySQL 连接 m, authority (char 1 必需 的 ) 
m, email (varchar 50) 
连接 名 称 : Ue ID Gat 11 必需 的 ) 
vex. B&B S epic S 
HPZ: Ta question (varchar 50 必需 的 ) 
sia. p sex (varchar 10 必需 的 ) 
tel (varchar 50) 
数据 库 : m, truename (varchar 50 必需 的 ) 
: m, username (varchar 20 必需 的 ) 
RA 视图 
k 预存 过 程 
图 4-20 设置 成 功 图 4-21 显示 绑 定 的 数据 库 


用 户 登 录 模块 的 设计 


本 市 主要 介绍 用 户 登 录 模 块 的 制作 ， 在 该 模块 中 将 进行 登录 的 用 户 称 为 会 员 ， 所 以 界面 
中 显示 的 是 “会 员 登 录 ” 了 字样 。 


LUUD 登录 页 面 的 设计 : 


在 用 户 访问 该 用 户 管理 系统 时 ， 首 先 要 进行 身份 验证 ， 这 个 功能 是 靠 登 录 页 面 来 实现 
的 。 所 以 登录 页 面 中 必须 有 要 求 用 户 输入 用 户 名 和 密码 的 文本 框 ， ee 
录 的 “登录 ”按钮 、 和 输入 错误 后 重新 设置 用 户 名 和 密码 的 “ 重 置 ” 按 钮 。 详 细 的 制作 步骤 
如 下 。 

(OD 首先 ， 来 看 一 下 用 户 登 录 系 统 的 首页 设计 ， 如 网 4-22 所 示 。 

(2) index.php 页 面 是 用 户 登 录 系 统 的 首页 ， 打 开 前 面 所 创建 的 index.php 页 面 ， 输 入 网 
页 标题 “PHP 用 户 管 理 系统 ”然后 执行 菜单 “文件 ”一 “保存 ”命令 ， 将 网 页 标题 保存 。 

G) 执行 菜单 “修改 ”一 “页 面 属 性 ”命令 ， 然 后 在 “背景 颜色 ”文本 框 中 输入 颜色 值 
为 #CCCCCC， 在 “上 边 距 ”文本 框 中 输入 0 像素 ， 这 样 设置 的 目的 是 为 了 让 页 面 的 第 一 个 
表格 能 置顶 到 上 边 ， 并 形成 一 个 灰色 底 纹 的 页 面 ， 设 置 如 图 4-23 所 示 。 

(40 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 进 入 “文档 ”窗口 ， 执 行 菜单 “插入 记录 ”一 
“表格 ”命令 ， 在 打开 的 “表格 ”对 话 框 中 ， 在 “ 行 数 ”文本 框 中 输入 需要 插入 表格 的 行 数 
为 3， 在 “ 列 数 ” 文 本 框 中 输入 需要 插入 表格 的 列 数 为 3。 在 “表格 宽度 ”文本 框 中 输入 775 
像素 ,“ 边 框 粗细 ”“ 单 元 格 边 距 ” 和 “单元 格 间 距 ” 都 为 0， 如 图 4-24 所 示 。 


H 
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图 4-24 设置 “表格 ”属性 


(5) 单 击 “确定 ”按钮 ， 这 样 就 在 “文档 ”窗口 中 插入 了 一 个 3 行 3 列 的 表格 。 将 鼠标 
放置 在 第 1 行 表 格 中 ， 在 “属性 ”面板 中 单 击 “ 合 并 所 选单 元 格 ， 使 用 跨度 ”按钮 图 标 
In KE 1 行 表格 合 并 ， 再 执行 菜单 “插入 记录 ”一 “图 像 ” 命 令 ， 打 开 “ 选 择 文件 ”对 
话 框 ， 在 站 点 images 文件 夹 中 选择 图 厂 01.gif， 如 图 4-25 所 示 。 
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相对 于 : Ard | index.php 


在 站 点 定 亿 中 更 吃 黑 让 的 链接 相对 于 
预 点 图 者 


图 4-25 “选择 图 像 源 文件 ”对 话 框 


(6) 单 击 “ 确 定 ” 按 钮 ， 就 在 表格 中 插入 了 此 图 片 ， 将 鼠标 放置 在 第 3 行 表格 中 ， 在 
“属性 ”面板 中 单 击 “合并 所 选单 元 格 ， 使 用 跨度 ”按钮 图 标 | 回 |， 将 第 3 行 所 有 列表 格 合 
并 ， 再 执行 菜单 “插入 记录 ”一 “图 像 ” 命 令 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 站 点 images 
文件 夹 中 选择 图 片 05.gif， 插 入 一 个 图 片 ， 效 果 如 图 4-26 所 示 。 
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4-26 插入 图 片 效 未 图 


CD 插入 图 片 后， 选择 插入 的 整个 表格 ， 在 “属性 ”面板 上 “对 齐 ” 下 拉 列 表 框 中 ， 先 
择 “ 居 中 对 齐 ” 命 令 ， 让 插入 的 表格 居中 对 齐 ， 如 图 4-27 所 示 。 
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4-27 设置 “居中 对 齐 ” 
(8) 把 光标 移 至 创建 表格 第 2 行 第 1 列 中 ， 在 “属性 ”面板 中 设置 高 上 度 为 456 像素 、 宽 
BE 179 像素 。 设 置 高 度 和 宽度 时 ， 根 据 背 景 图 像 而 定 ， 从 “背景 ”中 选择 该 站 点 中 images 
文件 夹 中 的 02.gif 文件 ， 得 到 的 效果 如 图 4-28 所 示 。 
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4-28 插入 图 上 厂 的 效果 图 


(9) 在 表格 的 第 2 行 第 2 列 和 第 3 列 中 ， 分 别 插 入 同 站 点 images 文件 夹 中 的 图 片 03.gif 
和 04.gif， 完 成 网 页 的 结构 搭建 ， 如 图 4-29 所 示 。 
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图 4-29 完成 的 网 页 背景 效果 图 


(10) 单 击 第 2 行 第 1 列 单元 格 ， 然 后 再 单 击 “ 文 档 ” 窗 口上 的 d£ H 在 <td> 和 
</td> 之 间 加 入 valign="top" (表格 文学 和 图 片 的 相对 捍 放 位 置 ， 可 选 值 为 top、 middle、 
bottom) 的 命令 ， 表 示 让 鼠标 能 够 自动 地 贴 至 该 单元 格 的 最 顶部， 设置 如 图 4-30 所 示 。 
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图 4-30 ”设置 单元 格 的 对 齐 方式 为 最 顶部 


注意 : 

文档 工具 栏 中 包含 按钮 和 弹出 的 菜单 ， 提 供 各 种 文档 “窗口 视图 ”( 如 “设计 ”、“ 拆 
分 ”和 “代码 ”视图 )、 各 种 查看 选项 和 一 些 常 用 操作 ( 如 在 浏览 器 中 预览 )。 

对 选项 说 明 如 下 。 

“代码 ”: 显示 代码 视图 ， 仅 在 “文档 ”窗口 中 显示 代码 视图 。 

“ 拆 分 ”: 显示 代码 视图 和 设计 视图 ， 在 “文档 ”窗口 的 一 部 分 中 显示 代码 视图 ， 而 在 另 
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一 部 分 中 显示 设计 视图 。 
“设计 ”: 显示 设计 视图 ， 仅 在 “文档 ”窗口 中 显示 设计 视图 。 
“标题 ?>: 允许 为 文档 输入 一 个 标题 ， 它 将 显示 在 浏览 器 的 标题 栏 中 。 
“没有 浏览 器 /检查 错误 ”: 可 以 检查 跨 浏 览 器 兼容 性 。 
“文件 管理 ”: 显示 文件 管理 弹出 菜单 。 
“在 浏览 器 中 预览 /调试 ?: 在 浏览 器 中 预览 或 调试 文档 ， 从 弹出 菜单 中 选择 一 个 浏览 器 。 
“刷新 设计 视图 F5”: 当 在 代码 视图 中 进行 更 改 后 刷新 文档 的 设计 视图 。 
“视图 选项 ”: 允许 为 代码 视图 和 设计 视图 设置 选项 ， 如 “标尺 ”、“ 网 格 ”、“ 文 件 头 ”内 
(4D) 单 击 “文档 ”窗口 上 的 | 设计 按钮， 返回 文 档 窗口 的 “设计 ”窗口 模式 ， 在 刚 创 
建 表格 的 单元 格 中 ， 执 行 亲 单 “ 插 入 记录 ”一 “表单 ”一 “表单 ”命令 ， 如 图 4-31 所 示 ， 
插入 一 个 表单 。 
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图 4-31 执行 “表单 ”命令 


C120 将 眼 标 放置 在 该 表单 中 ， 执 行 采 单 “ 插 入 记录 ”一 “表格 ”命令 ， 打开 “表格 ” 
对 话 框 ， 在 “ 行 数 ”文本 框 中 输入 5， 在 “ 列 数 ”文本 框 中 输入 2。 在 “表格 宽度 ”文本 框 
中 输入 179 像素 ， 在 该 表单 中 插入 5$ 行 2 列 的 表格 。 单 击 并 拖 动 鼠标 ， 分 别 选择 第 1 行 、 第 
2 行 和 第 5 行 表 格 ， 并 分 别 在 “属性 ”和 面板 中 单 击 使 用 “合并 所 选单 元 格 ， 使 用 跨度 ”按钮 
回 ， 将 这 几 行 表格 进行 合并 。 然 后 在 表格 的 第 1 行 输 入 “会 员 登 录 ”4 个 字 ， 在 第 2 行 第 1 
列 中 输入 文字 说 明 “ 用 户 名 ” 在 第 2 行 第 2 列 中 执行 菜单 “插入 记录 ”一 “表单 ”一 “、》 
本 域 ” 命 令 ， 插 入 一 个 单行 文本 域 表 单 对 象 ， 并 定义 文本 域名 为 “username”,“ 文 本 域 ” 属 
性 设置 及 此 时 的 效果 如 图 4-32a、b 所 示 。 

说 明 : 设置 文本 域 的 属性 说 明 如 下 。 

1) 在 “文本 域 ”文本 框 中 ， 为 “文本 域 ”指定 一 个 名 称 。 每 个 “文本 域 ”都 必须 有 一 
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个 唯一 名 称 。 表 单 对 象 名 称 不 能 包含 空格 或 特殊 字符 ， 可 以 任意 组 合 字 母 、 数 字 、 mE 


EZ O( )。 请 注意 ， 为 “文本 域 ”指定 的 标签 将 存储 该 域 的 值 (输入 的 数据 ) 的 变 ， 这 
是 发 送 给 服务 器 进行 处 理 的 值 。 
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4-32 输入 “用 户 名 ”和 搬入 “文本 域 ” 的 设置 


2 )“ 字 符 宽 度 ” 设 置 域 中 最 多 可 显示 的 字符 数 。 用 “最 多 字符 数 ” 指 定 在 域 中 可 We 
最 多 字符 数 ， 如 果 保 留 为 空白 ， 则 输入 不 受 限 制 。“ 字 符 宽度 ”可 以 小 于 “最 多 字符 数 ”"， 但 
大 于 “最 多 字符 数 ” 的 输入 则 不 被 显示 。 

3 )“ 类 型 ”用 于 指定 文本 域 是 “单行 "、“ 多 行 ”还 是 “密码 ” 域 。 单 行文 本 域 只 能 显 
_ 行 文字， 多 行 则 可 以 输入 多 行文 字 ， 达 到 字 we 密码 。 

4 )“ 初 始 值 ”指定 在 首次 载 入 表单 时 ， 域 中 显示 的 值 。 例 如 ， 通 过 包含 说 明 或 示例 值 ， 
可 以 指示 用 户 在 域 中 输入 信息 。 

5) “类 ”可 以 将 CSS 规则 应 用 于 对 象 。 


(13) 在 第 3 行 第 1 列表 格 中 输入 文字 说 明 “ 密 码 ” 在 第 3 行 表格 的 第 2 列 中 执行 菜单 
“插入 记录 ”一 “表单 ”一 “文本 域 ” 命 令 ， 插 入 密码 文本 域 表 单 对 象 ， 定 义 “文本 域 ” 名 
为 password。“ 文 本 域 ” 属性 设置 及 此 时 | 的 效果 如 图 4-33a. b 所 示 。 


属性 
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(14) 选择 第 4 行 单元 格 ， 执 行 染 单 “ 插 入 记录 ”一 “表单 ”一 “按钮 ”命令 两 次 ， 插 
入 两 个 按钮 ， 并 分 别 在 “属性 ”和 面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ” 选 
项 ， 一 个 为 “ 重 设 表单 ”选项 。“ 属 性 ”的 设置 如 图 4-34a、b Br. 
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4-34 设置 按钮 名 称 


(150 在 第 5 行 输入 “注册 痢 用 户 ” 文 本 ， 并 设置 一 个 转 到 用 户 注册 页 面 registerphp 的 
链接 对 象 ， 以 方便 用 户 注册 ， 和 输入 的 效果 如 图 4-35a. b 所 示 。 
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(16) 如 末 已 经 注册 的 用 户 瑟 记 了 密码 ， 还 布 望 以 其 他 方式 能 够 重新 获得 密码 ， 可 以 在 
表格 的 第 4 列 中 输入 “ 找 回 密码 ”文本 ， 并 设置 一 个 转 到 密码 合 询 页 面 lostpassword.php 的 
链接 对 象 ， 方 便 用 户 取 回 密 码 ， 如 图 4-36a、b 所 示 。 

(17) 表单 编辑 完成 后 ， 下 面 来 编辑 该 网 页 的 动态 内 容 ， 以 便 用 户 可 以 通过 该 网 页 中 
表单 的 提 区 实现 登录 功能 。 打 开 “ 服 务 右 行为 ”面板 ， 单 击 该 面板 上 按钮 四， 执行 全 单 
“用 户 身 份 验证 ”一 “登录 用 户 ” 命 令 ， 如 图 4-37 所 示 ， 向 该 网 页 添加 “登录 用 户 ” 的 服 
PARIT N o 

(18) 此 时 打开 “登录 用 户 ” 对 话 杠 ， 各 项 参数 设置 如 网 4-38 所 示 。 
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图 4-36 ”密码 查询 设置 
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4-37 添加 “登录 用 户 ” 服 务 需 行为 


PHP-*-MySQLtDreamweaver 动态 网 站 建设 从 入 门 到 精通 


MO BASH LA. : 


MPRA: 
sug. 


mpi, HA 

[] 转 到 前 一 个 WRLT 加 果 它 存在 》 
DRERAR HA 
基于 以 下 项 限制 访问 : © ”用 户 名 和 密码 

O 用 户 名 。 密 码 和 访问 级 别 

SEHRERRUB: 


图 4-38 “登录 用 户 ” 对 话 框 


该 对 话 框 中 各 项 设置 的 作用 如 下 。 

1) 从 “从 表单 获取 输入 ”下 拉 列 表 框 中 ， 选 择 该 服务 器 行为 使 用 网 页 中 的 forml 对 
销 ， 设 定 访 用户 登录 服务 占 行 为 的 用 户 数 据 来 源 为 表单 对 象 中 访问 者 填写 的 内 容 。 

2) 从 “用 户 名 字段 ”下 拉 列 表 框 中 ， 选 择 文 本 域 username 对 象 ， 设 定 该 用 户 登 录 服 务 
器 行为 的 用 户 名 数据 来 源 为 表单 的 username 文本 域 中 访问 者 输入 的 内 容 。 

3) 从 “密码 字段 ”下 拉 列 表 框 中 ， 选 择 文 本 域 password 对 象 ， 设 定 该 用 户 登录 服务 器 
行为 的 密码 数据 来 源 为 表单 的 password 文本 域 中 访问 者 输入 的 内 容 。 

4) 从 “使 用 连接 验证 ”下 拉 列 表 框 中 ， 选 择 用 户 登 录 服 务 器 行为 使 用 的 数据 源 连 接 对 
2 7j my member. 

50 从 “表格 ”下 拉 列 表 框 中 ， 选 择 该 用 户 登 录 服 务 器 行为 使 用 到 的 数据 库 表 对 象 为 
member。 

60 从 “用 户 名 列 ” 下 拉 列 表 杠 中， 选择 表 member 存储 用 户 名 的 字段 为 username。 

7) 从 “密码 列 ” 下 拉 列 表 杠 中， 选择 表 member 存储 用 户 密 码 的 字段 为 password. 

8) 在 “如 有 果 登 录 成功 ， 转 到 ”文本 框 中 输入 登录 成 功 后 ， 转 问 welcome.php W H. 

9) 在 “如 果 登 录 失 败 ， 转 到 ”文本 框 中 输入 登录 失败 后 ， 转 癌 loginfail.php 页 面 。 

100 选择 “基于 以 下 项 限制 访问 ”后 面 的 “用 户 名 和 密码 ” 单 选 按钮 ， 设 定 后 面 将 根据 
用 户 的 用 户 名 、 密 人 码 共同 决定 其 访问 网 页 的 权限 。 

(190 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 在 “ 服 
务 器 行为 ”面板 中 就 增加 了 一 个 “登录 用 户 ” 行 为 ， 如 图 4-39 所 示 。 

(200 表单 对 象 对 应 的 “属性 ”面板 的 动作 属性 值 如 图 4-40 所 示 ， 为 <?php echo $login 
FormAction; ?>。 它 的 作用 吏 是 实现 用 户 登 录 功 能 ， 这 是 一 个 Dreamweaver 上 自动 生成 的 动作 
代码 。 

(21) 执行 染 单 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 ， 完 成 网 站 的 首 


用 户 管 理 系统 开发 


页 制作 。 
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4-39 “服务 占 行 为 ”和 面板 


<?php echo $loginFormAction; ?> (oO 目标 (7T) | 图 XO 无 E 
mrs vj «nen exci 


4-40 表单 对 象 对 应 的 “属性 ”面板 


O 登录 成 功 和 失败 


当 用 户 输 入 的 登录 信息 不 正确 时 ， 束 会 转 到 loginfailphp 页 面 ， 显 示 登 录 失 败 的 信息 。 


如 果 用 户 输入 的 登录 信息 正确 ， 就 会 转 到 welcome.php 页 面 。 下 面 首先 来 制作 loginfail.php 
页 耐 ， 评 细 制 作 步 又 如 下 。 

(1) 执行 洒 单 “文件 ”一 “ 独 建 ”命令 ， 在 网 站 根 目录 下 刹 建 一 个 名 为 loginfail.php 的 
网 页 并 保存 。 

(2) 登录 失败 页 面 设计 如 图 4-41 所 示 。 在 “文档 ”窗口 中 选中 “这 里 ”文本 ， 在 其 对 
应 的 “属性 ”面板 上 的 “链接 ”文本 框 中 输入 index.php， 将 其 设置 为 指向 index.php 页 面 的 
链接 。 


BRAR 


ERAR. GRESERPISRESESIFH D SATA IE NR 
请 单 击 这 里 重新 登录 


4-41 登录 失败 页 面 loginfail.php 


(3) 执行 洒 蛙 “文件 ”一 “保存 ”命令 ， 完 成 loginfail.php 页 面 的 创建 。 

接 下 来 制作 welcome.php 页 耐 ， 详 细 制 作 的 步 又 如 下 。 

(1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 welcome.php 的 
网 页 并 保存 。 


f PHP+MySQL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(2) 用 类 似 制作 登录 失败 页 面 的 方法 制作 登录 成 功 页 面 的 静态 部 分 ， 如 图 4-42 Dr. 
G) 执行 沫 单 “ 窗 口 ” 一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 [村 按钮 ， 
在 弹出 的 某 音 中， 选择 “阶段 变量 ”选项 ， 为 网 页 中 定义 一 个 阶段 变量 ， 如 图 4-43 Br. 


_ 数据 库 | sE | 服务 器 行为 | -三 
CH 一 文档 类 型 : Fl 
记录 集 ( 查询 ) 
表单 变量 
EEUU URL 变量 em 
登录 成 功 4 | 阶段 变量 
PO Cookie 变量 
Mee : 服务 器 变量 
- E TARE 
EMTA TE Spry 数据 集 
TESEHREFESIFH P: 获 职 数据 源 ... 
图 4-42 ”登录 成 功 页 面 的 效果 图 图 4-43 ”添加 阶段 变量 


重点 说 明 : 

绑 定 面板 中 “阶段 变量 ”命令 经 第 使 用 ， 有 具体 的 功能 说 明 如 下 。 

阶段 变量 提供 了 一 种 对 象 ， 通 过 这 种 对 和 象 ， 用 户 信 息 得 以 存储 ， 并 使 该 信息 在 用 己 访 问 
的 持续 时 间 中 对 应 用 程序 的 所 有 页 都 可 用 。 阶 段 变 量 还 可 以 提供 一 种 超时 形式 的 安全 对 象 ， 
这 种 对 象 在 用 户 账 户 长 时 间 不 活动 的 情况 下 ， 终 止 该 用 户 的 会 话 。 如 果 用 户 忘记 从 Web 站 
点 注销 ， 这 种 对 象 还 会 释放 服务 器 内 存 和 处 理 资 源 。 


(4) 打开 “阶段 变量 ”对 话 框 ， 在 “名 称 ” 文 本 框 中 输入 “阶段 变量 ”的 名 称 MM 
username， 如 图 4-44 所 示 。 

(5) 设置 完成 后 ， 单 击 该 对 话 框 中 的 “人 确定” 按钮， 在 “文档 ”窗口 中 通过 拖 动 腿 标 选 
择 “XXXXXX” 文 本 ， 然 后 在 “ 绑 定 ”面板 中 选择 MM_username 变量 ， 再 单 击 “ 绑 定 ” 面 
板 底 部 的 “插入 ”按钮 ， 将 其 插入 到 该 “文档 ”窗口 中 设 定 的 位 置 。 插 入 完毕 ， 可 以 看 到 
4XXXXXX" XN li (Session. MM, username] EA AH, un] 4-45 所 示 。 这 样 ， 就 完成 了 
这 个 显示 登录 用 户 名 “阶段 变量 ”的 添加 工作 。 


Bip 


mW. Wiusemme | | L8 


REB 


图 4-44 “阶段 变量 ”对 话 框 图 4-45 插入 后 的 效果 
重点 提示 : 设计 阶段 交 量 的 目的 ， 是 在 用 户 登 录 成 功 后 ， 登 录 界 面 中 可 以 直接 显示 用 户 
的 名 字 ， 使 网 页 更 有 亲切 感 。 


(6) 在 “文档 ”窗口 中 拖 动 鼠 标 选 中 “注销 你 的 用 户 ” 文 本 。 执 行 菜单 “窗口 ”一 “ 服 
务 器 行为 ”一 “用 户 身份 验证 ”一 “注销 用 户 ” 命 令 ， 为 所 选中 的 文本 添加 一 个 “注销 用 


4X4 HERRAR 


户 ” 的 服务 器 行为 ， 如 网 4-46 所 示 。 
aa | 
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4-46 “注销 用 户 ” 命 令 


CI) 打开 “注销 用 户 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 

1)“ 在 以 下 情况 下 注销 ”用 于 设置 注销 时 机 ， 本 例 选 择 “ 单 击 链接 ” 单 选 按钮 ， 并 在 右 
边 的 下 拉 列 表 框 中 选择 “所 选 范围 : 注销 你 的 用 户 ” 这 样 当 用 户 在 页 面 中 单 击 “ 注 销 你 的 
HP T BESEDAATTERS BRE. 

2)“ 在 完成 后 ， 转 到 ”文本 框 用 于 注销 后 显示 的 页 面 ， 本 例 在 右 侧 文本 框 中 输入 
logootphp， 表 示 注 销 后 转 到 logootphp 页 面 ， 完 成 后 的 设置 如 图 4-47 所 示 。 


在 以 下 情况 下 注销 : © 单 击 链接 ;| 所 选 范围 ; ”注销 你 的 用 户 ” ~] 
O 页 面 载 入 
在 完成 后 ， 转 到 : logoot.php | 


4-47 ”设置 完成 后 的 “注销 用 户 ” 对 话 杠 


(8) 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对话 框 ， 返 回 到 “文档 ”窗口 。 在 “服务 
器 行为 ”面板 中 增加 了 一 个 “注销 用 户 ” 行 为 ， 同 时 可 以 看 到 “注销 用 户 ” 链 接 文本 对 应 的 
“属性 ”面板 中 的 “链接 ”属性 值 为 <?php echo $logoutAction ?>， 它 是 Dreamweaver 目 动 生 
成 的 动作 对 和 象 。 

(9) logoot.php 的 页 面 设计 比较 简单 ， 不 做 详细 说 明 ， 在 页 面 中 的 “这 里 ”处 指定 一 个 
链接 到 首页 index.php 就 可 以 了 ， 效 果 如 图 4-48 PZR. 


T5. C: M pachehtdocs'memberVlogoot. php (XHTML) -0X 


BERAE? 您 已 实 全 退出 


重新 登录 倩 单 击 习 里 。 


[kd Q 100 — 4518 x 131v 1 EK / 1 dh Unicode WIF-8) | — -: 
图 4-48 注销 用 户 页 面 设计 效 末 图 
(100. 执行 菜单 “文件 ”一 “保存 ”命令 ， 将 该 文档 你 存 到 本 地 站 所 中 。 编 辑 工作 完成 


后 ， 就 可 以 测试 该 用 户 登 录 系 统 的 执行 情况 了 。 文 档 中 的 “修改 您 的 注册 资料 ”链接 到 
userupdate.php 页 面 ， 此 页 面 将 在 后 面 的 修改 革 节 中 进行 介绍 。 


3 登录 功能 的 测试 


制作 好 一 个 系统 后 ， 需 要 测试 无 误 ， 才 能 上 传 到 服务 器 使 用 。 下 面 加 对 登录 系统 进行 如 
下 测试 。 

(1) 打开 下 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/member/， 打 开 index.php 页 面 ， 如 
图 4-49 所 示 。 
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4-49 打开 的 网 站 首页 


(2) 在 “用 户 名 ”和 “密码 ”文本 框 中 分 别 输 入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “ 登 
ox" TR. 

(3) 如 果 在 第 2 步 中 填写 的 登录 信息 是 错误 的 ， 或 者 根本 就 没有 输入 ， 则 浏览 器 就 会 转 
到 登录 失败 页 面 loginfailphp， 显 示 登 录 失 败 信 息 ， 如 图 4-50 所 示 。 
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4-50 登录 失败 页 面 loginfail.php 效果 


(4) 如 宁 输 入 的 用 户 名 和 密码 都 正确 ， 则 显示 登录 成 功 页 面 。 这 里 输入 的 是 前 面 数 据 库 
设置 的 用 户 design， 登 录 成 功 后 的 页 面 如 图 4-51 所 示 ， 其 中 显示 了 用 户 名 design. 
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4-51 登录 成 功 页 面 welcome.php 效果 


(5) 如 果 想 注销 用 户 ， 只 需要 单 击 “ 注 销 你 的 用 户 ” 超 链接 即 可 。 注 销 用 户 后 ， 浏 览 器 
束 会 转 到 页 面 logootphp， 然 后 单 击 “ 这 里 ” 回 到 首页 ， 如 图 4-52 所 示 。 全 此 ， 登 录 功 能 束 
测试 完成 。 


PHP 


J 注销 用 户 - Nicrosoft Internet Explorer mB) 
TFP AED 查看 收藏 以) IR() #5 w) Ed 


QAE- O- DBOR: wx o e- RBL 
地 址 四 ) | 四 http://127.0.0. 1/menber/1ogo0t.ph V| EJ PA HHE Q snett E 
BUTADA? 您 已 安全 退出 
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图 4-52 注销 用 户 页 面 效 果 


蕊 必用 户 注 册 模块 的 设计 


用 户 登 录 系 统 是 为 数据 库 中 已 有 的 老 用 户 登 录用 的 ， 一 个 用 户 管理 系统 还 应 该 提供 新 用 
户 注册 用 的 页 面 。 对 于 新 用 户 来 说 ， 通 过 单 击 index.php 页 面 上 的 “注册 新 用 户 ” 超 链接 ， 
进入 到 名 为 register.php 的 页 面 ， 在 该 页 面 中 实现 新 用 户 注册 功能 。 


ien HAARA 


register.php 页 面 主要 实现 用 户 注册 的 功能 ， 用 户 注册 的 操作 就 是 向 member.mdb 数据 库 
的 member 表 中 添加 记录 的 操作 ， 完 成 的 页 面 如 图 4-53 所 示 。 


T C: XApacheXhtdocs*memberkregister. php MISC 


PL." union 
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3. 网 上 付款 
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图 4-53 用户 注册 页 面 样式 
C) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 日 录 下 新 建 一 个 名 为 register.php 的 网 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


€S45 用 户 管理 系统 开发 


页 并 你 存 。 

(2) 在 Dreamweaver 中 使 用 制作 静态 网 页 的 工具 ， 完 成 如 图 4-54a、b 所 示 的 静态 部 
分 ， 这 里 要 说 明 的 是 ， 注 册 时 需要 加 入 一 个 “隐藏 域 ” 并 命名 为 authority, Vx E SUA TH 
0， 即 所 有 的 用 户 注册 的 时 候 默 认 是 一 般 访问 用 户 。 
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图 4-54  register.php 页 面 静 态 设 计 


重点 提示 : 在 为 表单 中 的 文本 域 对 象 命名 时 ， 由 于 表单 对 象 中 的 内 容 将 被 添加 到 
member 表 中 ， 因 此 设置 表单 对 和 象 中 的 文本 域名 与 数据 库 中 的 相应 字段 名 相同 ， 这 样 做 的 目 
的 是 当 该 表单 中 的 内 容 添 加 到 member 表 中 时 可 以 自动 配对 。 文 本 “密码 验证 ”对 应 的 文本 
框 命名 为 password1。 隐藏 域 是 用 来 收集 或 发 送信 息 的 不 可 见 元 素 ， 对 于 网 页 的 访问 者 来 
说 ， 隐 藏 域 是 看 不 见 的 。 当 表单 被 提交 时 ， 隐 藏 域 就 会 将 信息 用 设置 时 定义 的 名 称 和 值 发 送 
到 服务 器 上 。 


G) 还 需要 设置 一 个 验证 表单 的 动作 ， 用 来 检查 访问 者 在 表单 中 填写 的 内 容 是 售 满 足 数 
据 库 中 表 member 中 字段 的 要 求 。 在 将 用 户 盾 写 的 注册 资料 提交 到 服务 器 之 前 ， 首 先 对 用 户 
填写 的 资料 进行 验证 。 如 果 有 不 符合 要 求 的 信息 ， 可 以 癌 访 问 者 显示 错误 的 原因 ， 并 让 访问 
者 重新 输入 。 

(4) 执行 染 单 “窗口 ”一 “行为 ”命令 ， 则 会 打开 “行为 ”面板 。 单 击 “ 行 为 ”面板 
中 的 [ 国 按 钮 ， 从 打开 的 行为 列表 中 选择 “检查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 如 
图 4-55 所 示 。 

本 例 中 ， 设 置 username 文本 域 、password 文本 域 、password1 文本 域 、answer 文本 域 、 
truename 文本 域 、address 文本 域 为 “ 值 : 必需 的 和 “可 接受 : 任何 东西 ” 即 这 儿 个 文本 域 
必须 填写 ， 内 容 不 限 ， 但 不 能 为 至; tel 文本 域 和 qq 文本 域 设 置 的 验证 条 件 为 “ 值 : 必需 
的 “可 接受 数字 ” 表示 这 2 个 文本 域 必须 填写 数字 ， 不 能 为 空 ，e-mail 文本 域 的 验证 
条 件 为 “ 值 : 必需 的 入 “可 接受 : 电子 邮件 ” 表示 该 文本 域 必 须 填写 电子 邮件 地 址 ， 且 不 


bB oL, 2x 
能 为 容 。 


"s PHP-*MySQL*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 
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O EZA O 数字 从 


图 4-55 设置 “检查 表单 ”对 话 框 


(50 设置 完成 后 ， 单 击 “确定 ”按钮 ， 完 成 对 检 奉 表单 的 设置 。 
(6 在 “文档 ”窗口 中 单 击 工具 栏 上 的 [到 | 扩 钮 ， 转 到 代码 编辑 窗口 ， 然 后 在 验证 表 
单 动 作 的 源 代 人 码 中 修改 如 下 的 代码 ， 主 要 是 实现 中 文 汉化 的 功能 。 
<script type= text/Javascript"» 
/宣告 脚本 语言 为 JavaScript 
function MM validateForm() { //v4.0 
if (document. getElementById){ 


var 1,p,q,nm,test,num,min,max,errors=",args=MM_validateForm.arguments; 
for (120; 1<(args.length-2); 1+=3) { testzargs[1-2]; val=document.getElementById(args[1]); 
if (val) { nm=val.name; if ((val=val.value)!="") { 
if (test.indexOf(isEmail')!=-1) { pzval.indexOf( (5; 
if (p«1 || p==(val.length-1)) errors+= '+nm+' £i; Z4 An"; 
/如 末 提 交 的 邮箱 地 址 表单 中 不 是 邮件 格式 ， 则 显示 为 “需要 和 输入” 
} else if (test!='R') ( num = parseFloat(val); 
if (isNaN(val)) errors+='- '+nm+' 需 要 输入 数字 .my 
/如 有 果 提 交 的 电话 表单 中 不 是 数字 ， 则 显示 为 “需要 输入 数字 ” 
if (test.indexOf('inRange?) != -1) { p=test.indexOf(':'); 
min-test.substring(8,p); max-test.substring(p4-1); 
if (num&min || max«num) errors+='- '+nm+' 震 要 输入 数字 '+min+' and '+max+'.\n'; 
// 如 下 提交 的 QQ 表单 中 不 是 数字 ， 则 显示 为 “需要 输入 数字 ” 
} } } else if (test.charAt(0) == RD errors += ~ '+nm+' is 需要 输入 .\n'; } 
// 如 果 提 交 的 地 址 表单 为 室 ， 则 显示 为 “需要 输入 ” 
} if (errors) alert( 注 册 时 出 现 如 下 错误 :n+errors); 
// 如 果 出 错 将 显示 “注册 时 出 现 如 下 错误 : 
document.MM returnValue = (errors == "); 


jj 
</script> 
编辑 代码 完成 后 ， 单 击 工具 栏 上 的 | GE | 按钮， 返回 到 “文档 ”窗口 。 
此 时 ， 可 以 测试 一 下 执行 的 效果 ， 不 输入 相应 的 信息 ， 然 后 单 击 “ 提 交 ” 按 钮 ， 则 会 打 
开 一 个 警告 框 ， 如 图 4-56 所 示 。 
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4-56 “提示 错误 ”对 话 杠 


(7) 在 该 网 页 中 添加 一 个 “插入 记录 ”的 服务 融 行为 。 执 行 菜 单 “ 和 窗口” 一 “服务 露 行 
H? 命令， 打开“ 服务 器 行为 ”面板 。 单 击 该 面板 上 | 蔬 | 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 插 
入 记录 ， 命令 ， 则 会 打开 “插入 记录 ”对 话 框 ， 如 图 4-57 Bp. 
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4-57 执行 “插入 记录 ”操作 


(8) 在 “插入 记录 ”对 话 框 中 进行 如 下 设置 。 

D 从 “连接 ”下 拉 列 表 框 中 选择 mymember 作为 数据 源 连 接 对 象 。 

2) 从 “插入 表格 ”下 拉 列 表 框 中 选择 member 作为 使 用 的 数据 库 表 对 象 。 

3) 在 “插入 后 ， 转 到 ”文本 框 中 ， 设 置 当 记录 成 功 添 加 到 表 member 后 转 到 regok.php 
网 页 。 

4) 在 对 话 框 下 半 部 分 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 member. 中 的 字段 一 一 对 应 
起 来 。 设 置 完成 后 该 对 话 框 如 图 4-58 所 示 。 


PHP+ QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 
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图 4-58 设置 “插入 记录 ”对 话 框 


(9) 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 此 时 的 设 
计 样 式 如 图 4-59 所 示 。 
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图 4-59 插入 记录 后 的 效果 图 


(100 用 户 名 是 用 户 登 录 的 身份 标记 ， 用 户 名 是 不 能 重复 的 ， 所 以 在 添加 记录 之 前 ,一 
定 要 先 在 数据 库 中 判断 该 用 户 名 是 否 已 存在 ， 如 有 果 存 在 ， 则 不 能 进行 注册 。 在 Dreamweaver 
中 提供 了 一 个 检查 新 用 户 名 的 服务 器 行为 ， 单 击 “ 服 务 器 行为 ”面板 上 四 按钮 ， 在 弹出 的 这 
单 中 ， 执 行 “ 用 户 映 份 验证 ”一 “检查 新 用 户 名 ”命令 ， 如 图 4-60 所 示 。 

此 时 ， 会 打开 一 个 “检查 新 用 户 名 ”对 话 框 ， (cod 话 框 中 进行 设置 。 

D Æ "HER" prt PISTE username 字段 。 
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4-60 “检查 新 用 户 名 ”命令 


2) 在 “如 果 已 存在 ， 则 转 到 ”文本 框 中 输入 regfail.php。 表 示 如 果 用 户 名 已 经 存在 ， 则 
转 到 regfail.php 负面， 显示 注册 失败 信息 ， 该 网 页 将 在 后 面 编辑 。 
设置 完成 后 的 对 话 框 显示 如 图 4-61 所 示 。 


TECHNO S 


用 户 名 字段 
DREFE RESI E 


4-61 设置 “检查 新 用 户 名 ”对 话 框 
(11) 设置 完成 后 ， 单 击 该 对 话 框 中 的 “确定 ”按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ” 


窗口 。 在 “服务 器 行为 ”面板 中 ， 增 加 了 一 个 “检查 新 用 户 名 ”行为 ， 再 执行 染 单 “文件 ” 
一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 氮 中 ， 完 成 本 页 的 制作 。 


为 了 方便 用 户 登 录 ， 应 该 在 regok.php 页 面 中 设置 一 个 转 到 index.php. 页 面 的 文字 链接 ， 
以 方便 用 户 进 行 登 录 。 同 时 ， 为 了 方便 访问 者 重 靳 进行 注册 ， 则 应 该 在 regfailphp 页 和 设置 
一 个 转 到 registerphp 页 面 的 文子 链接 ， 以 方便 用 户 进行 重新 登录 。 本 节制 作 显示 注册 成 功 和 


失败 的 页 面 信息 。 
(1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 regok.php 的 网 
页 并 保存 。 


PHP 


(2) regok.php 页 面 如 网 4-62 所 示 。 制 作 比 较 简 单 ， 其 中 “这 里 ”文本 设置 为 指 问 
index.php 页 面 的 链接 。 
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4-62 注册 成 功 regok.php 负面 


(3) 如果 用 户 和 输入 的 注册 信息 不 正确 或 用 户 名 已 经 存在 ， 则 应 该 癌 用 户 显示 注册 失败 的 
信息 。 这 里 再 新 建 一 个 regfail.php 页 面 ， 访 页 面 的 设计 如 图 4-63 所 示 ， 其 中 “这 里 ”文本 
设置 为 指 问 register.php 页 面 的 链接 。 


a ona td php (XHTML) 


~ hb 
: 购物 中 心 | €mRUK 客户 留言 联系 我 们 = 
SI pm L— 7777777] 


| 产品 分 类 | EL 


E 掌上 电脑 
:不 好 意思 ， 你 注册 的 用 户 名 已 经 被 注册 。 


:请 单 击 这 里 重新 注册 4 
É 联想 手提 电脑 


E 


1. 选 购 产品 
2. 确 定 订 购 


Alli 


2 3 
(RI Q 100%  v|T60 x 537v 83 K / 2# Unicode (UTF-8) — 


4-63 注册 失败 regfail.php 页 面 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


用 户 管 理 系 统 开 发 


1E S 注册 功能 的 测试 


CT ls 
(1) 打开 IE 浏览 上 器， 在 地 址 栏 中 输入 http://127.0.0.1/member/register.php， 打 开 register. 
php 文件 ， 如 图 4-64 所 示 。 


| vic) amu) boo pma TAG) Whi 
G- o- Dourn reme ejna 
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4-64 打开 的 测试 页 面 


(2) 可 以 在 该 注册 页 面 中 输入 一 些 不 正确 的 信息 ， 如 漏 填 username. password 等 必需 字 
段 ， 或 填写 非法 的 E-mail 地址 ， 或 在 确认 密码 时 两 次 输入 的 密 但 不 一 致 ， 以 测试 网 页 中 验 
证 表单 动作 的 执行 情况 。 如 宋 填 写 的 信息 不 正确 ， 则 浏览 右 应 该 打开 警告 枉 ， 回 访问 者 显示 
错误 原因 。 如 图 4-65 所 示 是 一 个 警告 框 示 例 。 


了 会 只 T3 EU! E:crosxzof*t Internet 
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图 4-65 ”出 错 提示 
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(3) 在 该 注册 页 和 面 中 注册 一 个 已 经 存在 的 用 户 名 ， 如 输入 design 测试 新 用 户 服务 器 行为 
的 执行 情况 ， 然 后 单 击 “确定 ”按钮 ， 此 时 由 于 用 户 名 已 经 存在 ， 浏 览 占 会 目 动 转 到 
regfail.php WH, WE 4-66 所 示 ， 告 诉 访问 者 该 用 户 名 已 经 人 存在。 此 时 ， 访 问 者 可 以 单 击 
“这 里 ”链接 文本 ， 返 回 registerphp HE, MEEI TNEI- 


TRA - Nicrosoft Internet Explorer 

xo) ec) Em mo 工具 dT) Woo 

Qgsme-O |i P*-*s «mx 6 23-202 

IEE D) E] bt //127.0.0 1/asaber/regfail Here quaer mns etin wo rw um* - EPS us Qn n 
- —— 


SHEER LG nso Ed 
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购物 中 心 5: 客户 留言 联系 我 们 
特别 推荐 
imam 
THRE.TrfOOescEWr. 
清单 击 信 时 重新 注 舱 ? 


图 4-66 注册 失败 页 面 显 示 


(4) 在 该 注册 页 耐 中 填写 正确 的 注册 信息 ， 单 击 “ 确 定 ” 按 钮 。 由 于 这 些 注册 资料 完全 
正确 ， 而 且 这 个 用 户 名 没有 重复 ， 浏 览 需 会 转 到 regok.php 页 面 ， 问 访问 者 显示 注册 成 功 的 
信息 ， 如 图 4-67 所 示 。 此 时 ， 访 问 者 可 以 单 击 “ 这 里 ”链接 文本 ， 转 到 index.php 页 面 ， 以 
便 进 行 登录 。 
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4-67 注册 成 功 页 面 


在 MySQL 中 打开 用 户 数 据 库 文件 member， 查 看 其 中 的 member 表 对 象 的 内 容 。 此 时 可 
以 看 到 ， 在 该 表 的 最 后 已 创建 了 一 条 新 记录 ， 其 中 的 数据 就 是 刚刚 在 网 页 register.php 中 提交 
的 注册 用 户 的 信息 ， 如 图 4-68 所 示 。 


Q9) Show SQL help 
dh Table Editor options 
Restore default size 


《 
| Grid view | FormView | Print Data 
Records fetched: 2/2 O LIMITO, 1000 


4-68 K member 中 添加 了 一 条 新 记录 


全 此， 基本 完成 了 用 户 管 理 系 统 中 注册 功能 的 开发 和 测试 。 在 制作 的 过 程 中 ， 可 以 根据 
制作 网 站 的 需要 适当 加 入 其 他 更 多 的 注册 文本 域 ， 也 可 以 给 需要 注册 的 文本 域名 称 部 分 添加 
星 号 〈*)， 提 醒 注 册 用 户 注意 。 


蕊 更 遇 ”资料 修改 模块 的 设计 


修改 注册 用 户 资料 的 过 程 就 是 往 用 户 数 据 表 中 更 新 记录 的 过 程 ， 本 市 重 扣 介绍 如 何在 用 
户 管理 系统 中 实现 用 户 资料 的 修改 功能 


O 修改 资料 页 面 


该 页 面 主要 是 把 用 户 所 有 资料 部 列 出 ， 通 过 “更 新 记录 ”命令 实现 资料 修改 的 功能 。 具 


体 的 制作 步骤 如 下 。 

(C1) 首先 制作 用 户 修改 资料 的 页 面 。 该 页 面 和 用 户 注册 页 面 的 结构 十 分 相似 ， 可 以 通过 
对 register.php 页 面 的 修改 来 快速 得 到 所 需要 的 记录 更 新 页 面 。 打 开 register.php 页 面 ， 执 行 菜 
单 “ 文 件 ” 一 “ 男 存 为 ”命令 ， 将 该 文档 为 存 为 userupdate.php， 在 第 一 行 加 入 如 下 代码 : 


<?php 
session_start(); 
?>// 让 session 环境 启动 


(2) 执行 菜单 “窗口 ”一 “服务 嚣 行为” 命令， 打开“ 服务 露 行为” 面板。 在 “服务 器 行 
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为 ”面板 中 删除 全 部 的 服务 器 行为 并 修改 其 相应 的 文学 ， 该 页 面 修改 完成 后 如 图 4-69 所 示 。 


局 C: \Apache\htdocs\member\userupdate. php (XHTML) -0X 
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|| 购物 流程 


1. 选 购 产 品 
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2. 确 定 订购 1 E 

3. 网 上 付款 : 

E 2 v 
< TIT | > 
<body> (k]éy Q [00%  .|T49 x 511» 66 K / 2 19 Unicode (UTF-8) - 


图 4-69  userupdate.php 静态 页 面 


(3) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 |[ 册 | 按钮 ， 
在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 )” 选 项 ， 则 会 打开 “记录 和 集 ” 对 话 框 。 

在 该 对 话 框 中 进行 如 下 设置 。 

1) 在 “名 称 ” 文 本 框 中 输入 upuser 作为 该 “记录 集 ” 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 选择 “user 数据 源 ” 连 接 对 和 象 为 mymember。 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 和 象 为 member. 

4) 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

50 在 “ 饶 选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 UserName= 阶 段 变 量 / MM Username. 

完成 后 的 设置 如 图 4-70 所 示 。 


e. 
si. 


x 9 全 部 O weeds 
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questi T 
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图 4-70 设置 “记录 和 集 ” 对 话 框 


学 人 请 也 用 户 管理 系统 开发 


(4) 设置 完成 后 ， 单 击 该 对 话 框 上 的 “确定 ”按钮 ， 完 成 记录 集 的 绑 定 。 
(5) 完成 记录 集 的 绑 定 后 ， 将 upuser 记录 集中 的 字段 绑 定 到 页 面 中 相应 的 位 置 ， 注 意 插 
入 一 个 隐藏 域 为 ID， 议 置 在 用 户 名 字段 的 后 面 ， 如 图 4-71 所 示 。 


E] C: N\Apache\htdocs\member\userupdate. php (XHTML) * -0X 


EAD nymenber. php TY 
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== 
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图 4-71 绑 定 动态 内 容 后 的 userupdate.php 页 面 


(6) 对 于 网 页 中 的 单 选 按钮 组 sex 对 象 ， 绑 定 动态 数据 可 以 按照 如 下 方法 : 单 击 “ 服 务 
器 行为 ”面板 上 | 直接 钮 ， 在 弹出 的 菜单 中 ， 执 行 “动态 表单 元 素 ” 一 “动态 单 选 按钮 ” 命 
令 ， 设 置 动态 单 选 按钮 组 对 象 。 打 开 “ 动 态 单 选 按钮 组 ”对 话 框 ， 从 “动态 单 选 按钮 组 ” 下 
diia 选择 forml 表单 中 的 单 选 按钮 组 sex. Hh; XEHUBARIC LAE H 

E E 
ec dene 动态 绑 定 ， 设 置 完成 后 对 话 框 如 图 4-72b. c 所 示 。 


username 
password 
question 
anzwer 


truename 


单 选 掖 钮 组 : "sex" E EH “forml” v 


ERASE: [<?php echo Srow upuser[ sex | {Zi : LES 
: "x 
E: | 他 php echo $row upuser[' sex! ]; 7 


图 4-72 ”设置 “动态 单 选 按钮 ”对 话 框 
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动态 列表 / 羔 单 


"question" (E RÆ “forml” 
: |+| -J 
标签 


你 最 好 的 朋 ... 
你 小 学 上 学 
你 妈妈 的 名 
你 的 生日 是 


E B 记录 集 的 选项 : |upuser v 


: |question v 


| 
: [<?php $row upuser[' question | 到 


c) 
4-72 设置 “动态 单 选 按钮 ”对 话 框 《〈 续 ) 
(7) 单 击 “ 服 务 器 行为 ”面板 上 外 按 钮 ， 在 弹出 的 于 音 中， 选择 “更 新 记录 ”选项 ， 为 
网 页 添加 “更 新 记录 ”的 服务 砷 行为 ， 如 图 4-73 所 示 。 
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4-73 选择 “更 新 记录 ”选项 


(8) 打开 “更 新 记录 ”对 话 框 ， 该 对 话 框 与 “插入 记录 ”对 话 框 十 分 相似 ， 有 基体 的 设置 
情况 如 图 4-74 所 示 ， 这 里 不 再 复述 。 

(9) 设置 完成 后 ， 单 击 “ 人 确定” 按钮， 关闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 再 执行 苹 
单 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 


重点 提示 : 由 于 本 页 的 MM Username 值 是 来 自 上 一 页 注册 成 功 后 的 用 户 名 值 ， 所 以 单 
独 测试 是 会 提示 出 错 的 。 要 先 登 录 后 ， 在 登录 成 功 页 面 单 击 “ 修 改 您 的 注册 资料 ” 超 链接 到 


4s 用 户 管理 系统 开发 


该 页 面 才 会 产生 效果 ， 这 在 后 面 的 测试 实例 中 将 进行 介绍 。 


: | mymemb er 


member 


”合用 FOR ver aana, 作为 E paetae 
irr A ' FORM. password SSBBÍEM ， ER 
' question A ' FORM. question RREA TE 

'answer' M’ P answer’ XRHRBTEA ， ES 

'truename! 从: FORM. turename' 获取 值 作为 “ TE 

'sex' M’ FORM. sex WEYER ' 30A 

'address' JA 'FORM.address' REAR EE 


值 : FORM. username v | 
提交 为 : | 整数 Y 器 主妇 
在 更 新 后 ， 转 到 : userupdat eok. php | 


图 4-74 设置 “更 新 记录 ”对 话 框 


4.42 更 新 成 功 页 面 | 


用 户 修 改 注册 资料 成 功 后 ， 就 会 转 到 userupdateok.php。 在 该 网 页 中 ， 应 该 同 用 户 显 示 
资料 修改 成 功 的 信息 。 除 此 之 外 ， 还 应 该 考虑 两 种 情况 ， 如 果 用 户 要 继续 修改 资料 ， 则 为 其 


提供 一 个 返回 到 userupdate.php 页 和 面 的 超 文 本 链接 ; 如 果 用 户 不 需要 修改 ， 则 为 其 提供 一 个 
转 到 用 户 登 录 页 面 index.php 页 面 的 超 文本 链接 。 有 其 体 的 制作 步骤 如 下 。 

CIO 执行 染 单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 userupdateok. 
php 的 网 页 并 保存 ， 在 第 一 行 加 入 如 下 代码 : 


<?php 
session start(); 
?>1/ 让 session 环境 局 动 。 


(2) 为 了 回 用 户 提 供 更 加 友好 的 界面 ， 应 该 在 网 页 中 显示 用 户 修改 的 结果 ， 以 供用 户 检 
答 修 改 是 否 正 确 。 首 先 应 该 定义 一 个 记录 集 ， 然 后 将 绑 定 的 记录 集 插入 到 网 页 中 相应 的 位 
置 ， 其 方法 跟 制 作 页 面 userupdate.php 的 方法 一 样 。 通 过 在 表格 中 添加 记录 集中 的 动态 数据 
对 象 ， 把 用 户 修改 后 的 信息 显示 在 表格 中 。 这 里 不 做 详细 说 明 ， 请 参考 前 面 一 小 节 内 容 ， 最 
终结 果 如 图 4-75 所 示 。 


PIJ 测试 修改 资料 


编辑 工作 完成 后 ， 就 可 以 测试 该 修改 资料 功能 的 执行 情况 了 。 

(1) 打开 正 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/member/index.php, 1]JT index.php 
文件 。 在 该 页 面 中 进行 登录 ， 登录 成 功 后 进入 welcome.php 页 面 ， 在 welcome.php 页 面 单 击 
“修改 您 的 资料 ” 超 链 接 ， 转 到 userupdate.php 页 面 ， 如 图 4-76 所 示 。 
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图 4-75 ”设计 “更 新 成 功 的 页 面 ” 
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4$ Internet 
图 4-76 修改 admin 用 户 注册 资料 


(2) 在 该 页 面 中 进行 一 些 修改 ， 然 后 单 击 “提交 ”按钮 ， 将 修改 结果 发 送 到 服务 占 中 。 
—€——— 浏览 器 会 转 到 userupdateok.php 页 面 中 ， 显 示 修 改 资 料 成 功 的 信 
县 ， 同 时 还 显示 了 该 用 户 修改 后 的 资料 信息 ， 并 提供 转 到 修改 成 功 页 面 和 转 到 主页 面 的 链接 对 
象 ， 这 里 对 “真实 姓名 ”进行 了 修改 ， 单 击 “ 修 改 ” 按 钮 转 到 修改 成 功 页 面 ， 效 果 如 图 4-77 
所 示 。 


— 用 户 管理 系统 开发 


à 更 新 成 功 一 Nicrosoft Internet Explorer 加 回国 
TFP ”编辑 人 下) ”查看 0) REA 工具 (Ty 帮助 0 : 


QAE- O-iXi2(» DmsS* zk 6 A- SBL 
地 址 (D) &) http: //12T. 0. 0. 1/member/uzerupdateok. php? 元 输 六 关键 梧 搜索 S EEI 链接 © SnagIt gr 


LG: [s 
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`ta | > 
购物 流程 : 13800438000 


83560148 


1. 选 购 产 品 


2. 确 定 订购 密码 提示 问题 : | 你 最 好 的 朋友 是 ? 
3. 网 上 付款 SCRMBTUEX : lwo 

4 .填写 信息 : 重新 修改 MERN 

5. 签 收 产 品 : 


BJ 


4-77 修改 成 功 
上 述 测试 结果 表明 ， 用 户 修改 资料 页 面 已 经 成 功 制作 。 
| Section. 


加 时” 密码 查询 模块 的 设计 


在 用 户 注 册 时 ， 页 面 设 计 有 密码 提示 问题 和 答案 文本 框 ， 其 作用 是 ， 当 用 户 和 未 记 密码 
时 ， 可 以 通过 这 个 问题 和 答案 到 服务 顺 中 找 回 遗失 的 密码 。 实 现 的 方法 是 判断 用 户 提 供 的 答 
案 与 数据 库 中 答案 是 售 相 同 ， 如 条 相同 ， 则 可 以 找 回 遗失 的 密码 。 


IUE 密码 查询 XI 面 ZZ 


本 市 主要 制作 密码 合 询 负面 lostpassword.php， 具 体 的 制作 步骤 如 下 。 


(1) 执行 染 单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 lostpassword.php 
的 网 页 并 保存 。lostpassword.php 页 面 是 用 来 让 用 户 提交 所 要 查询 遗失 密码 的 用 户 名 的 页 面 。 
该 网 页 的 结构 比较 简单 ， 设 计 后 的 效果 如 图 4-78 所 示 。 

(2) 在 “文档 ”窗口 中 选中 表单 对 象 ， 然 后 在 其 对 应 的 “属性 ”面板 中 ， 在 “表单 名 
称 ” 文 本 框 中 输入 forml1， 在 “动作 ”文本 框 中 输入 showquestion.php 作为 该 表单 提交 的 对 
象 页 面 。 在 “方法 ”下 拉 列 表 框 中 选择 POST 作为 该 表单 的 提交 方式 ， 如 图 4-79a 所 示 。 接 
下 来 将 输入 用 户 名 的 文本 域 命名 为 inputname， 如 图 4-79b 所 示 。 
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|| 购物 流程 


1. 选 购 产 品 
2. 确 定 订 购 
3. 网 上 付款 
4. 填 写 信 息 
5. 签 收 产 品 


4—78 lostpassword.php X Hi 


Et 
EN ILES 动作 [showguestion pe — 710 — | (9 Bim| — — v| 类 | 无 v 
Bik rr v) WENSH ~» 
a) 
尾 性 
加 X 字符 宽度 W) | 类 型 由 单行 (5) Osam OSME) SO | 无 xl 
最 多 字符 数 | | WMBODO 14 
口 禁 用 0) 
[]Ri£ R) 
b) 
图 4-79 设置 表单 提交 的 动态 属性 
重点 说 明 : 


表单 属性 设置 面板 中 的 主要 选项 作用 如 下 。 

1) 在 “表单 名 称 ” 文 本 框 中 ， 输 入 标志 该 表单 的 唯一 名 称 。 命 名 表单 后 ， 就 可 以 使 用 
脚本 语言 引用 或 控制 该 表单 。 如 果 不 命 名 表单 ， 则 Dreamweaver 使 用 语法 forml、from2、… 
生成 一 个 名 称 ， 并 在 向 页 面 中 添加 每 个 表单 时 递增 n VM. 

2) 在 “方法 ”下 拉 列 表 框 中 ， 选 择 将 表单 数据 传输 到 服务 器 的 方法 。POST 方法 将 在 
HTTP HR FRAR ŽA. GET 方法 将 表单 数据 附加 到 请 求 该 页 面 的 URL F, ÆRU 
置 ， 但 其 缺点 是 表单 数据 不 能 太 长 ， 所 以 本 例 选 择 POST 方法 。 

3 )“ 目 标 ” 下 拉 列 表 框 用 于 指定 返回 窗口 的 显示 方式 ， 各 目标 值 含义 如 下 : 

blank 在 未 命名 的 新 窗口 中 打开 有 目标 文档 。 

parent 在 显示 当前 文档 的 窗口 的 父 窗口 中 打开 有 目标 文档 。 

sef 在 提交 表单 所 使 用 的 窗口 中 打开 目标 文档 。 

top 在 当前 窗口 的 窗 体内 打开 目标 文档 。 此 值 可 用 于 确保 目标 文档 占用 整个 窗口 ， 即 使 
原始 文档 显示 在 框架 中 。 
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当 用 户 在 lostpassword.php 页 面 中 输入 用 户 名 ， 并 单 击 “提交 ”按钮 后 ， 这 时 会 通过 表 

单 将 用 户 名 提交 到 showquestion.php 页 面 中 ， 该 页 面 的 作用 就 是 根据 用 户 名 从 数据 库 中 找到 

对 应 的 记录 的 提示 问题 并 显示 在 showquestion.php 页 面 中 ， 用 户 在 该 页 面 中 输入 问题 的 答 

案 。 下 面 就 制作 显示 问题 的 页 面 。 | 
(3) 新 建 一 个 文档 。 设 置 好 网 页 属性 后 ， 输 入 网 页 标题 “查询 问题 ” MATRA "3c 记 

件 ” 一 “保存 ”命令 ， 将 该 文档 保存 为 showquestion.php。 
(4) 在 Dreamweaver 制作 静态 网 页 ， 完 成 的 效果 如 图 4-80 所 示 。 


E C: \Apache\htdocs\member\showauestion. php (XHTML) * -0x 


mese | z 


1. 选 购 产 品 :该 用 户 名 不 存在 4 
2. 确 定 订购 : 
3. 网 上 付款 


< TIT 3 
<body> <table> <tr> <td> <form#forml > <p> [R] Q 100$  .|T25 x 421v 83 K / 2 $9 Unicode (UTF-8) 


图 4-80  showquestion.php FER I AUR 


(5) 在 “文档 ”窗口 中 选中 表单 对 象 ， 在 其 对 应 的 “属性 ”面板 中 ,“ 动 作 ” 文 本 框 中 
输入 showpassword.php 作为 该 表单 提交 的 对 象 页 面 。 在 “方法 ”下 拉 列 表 框 中 选择 POST fF 
为 该 表单 的 提交 方式 ， 如 图 4-81a 所 示 。 接 下 来 将 输入 密码 提示 问题 答案 的 文本 域 命名 为 
inputanswer， 如 图 4-81b 所 示 。 


BIE 


[7l 表单 ID 动作 showpassword.php 号 目标 (T) | v | 2$ (C) | 无 v 
: Jr [ros "E" Y 


a) 
Ir 文本 域 字符 宽度 | 类 型 Oge Osam — Oso 类 (C) 无 v 
景 多 字符 数 | ”| 初始 值 (I) | | 多 
OSAM) 
[ ] Rit () 
b) 


图 4-81 设置 表单 提交 的 属性 
(60 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 [二 按钮 ， 


从 打开 的 玉音 中 选择 “记录 集 (查询 )” 选 项 ， 则 会 打开 “记录 和 集 ”对 话 框 。 
(7) 在 该 对 话 框 中 进行 如 下 设置 。 
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1) 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 选择 数据 源 连接 对 象 为 mymember。 

3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 member. 

4) 在 “ 列 ” 栏 中 选择 “ 选 定 的 ” 单 选 按钮 ， 然 后 从 下 拉 列 表 框 中 选择 username 和 
question 。 

5) 在 “和 沛 选 ” 栏 中 ， 设 置 记录 集 过 滤 的 条 件 为 username: =， 表 单 变 量 : inputname， 
表示 根据 数据 库 中 username 字段 的 内 容 是 否 与 从 上 一 个 网 页 表单 中 的 inputname 表单 对 象 所 
传递 过 来 的 信息 完全 一 致 ， 来 过 滤 记 录 对 象 。 

完成 后 的 设置 如 图 4-82 所 示 。 


名 和 i 
wn. 
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图 4-82 设置 “记录 集 ” 对 话 框 


(80 设置 完成 后 ， 单 击 该 对 话 框 上 的 “确定 ”按钮 ， 关 财 该 对 话 框 。 返 回 到 “文档 ”窗口 。 
(9) 将 Recordsetl 记录 集中 的 question 字段 绑 定 到 页 面 中 相应 的 位 置 ， 如 图 4-83 所 示 。 


T C: NpachelhtdocsWmemberlshowquestion php (XHTML)* SEIX 


EASP mymember. php 


数码 相机 | 河 题 提示 Recordset1 question} 
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名 牌 手机 HEER: | 
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1. 选 购 产 品 该 用 户 名 不 存在 


< ll 
<body> <table> Ctr? <td> <form#forml> DS q 1008  4|T25 x 403» 86 K / 2 $^ Unicode (UTF-8) 
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(100. 执行 业 单 “插入 记录 ”一 “表单 ”一 “隐藏 域 ”命令 ， 在 表单 中 插入 一 个 表单 隐 
藏 域 ， 然 后 将 该 隐藏 域 的 名 称 设置 为 username. 

(11) 选中 该 隐藏 域 ， 转 到 “ 绑 定 ”面板 ， 将 Recordsetl 记录 集中 的 username 字段 绑 定 
到 该 表单 隐 荐 域 中 ， 如 图 4-84 所 示 。 


LB ERË (Recordzetl) 


: 4 ^ question 


| s$ ession 


e 
H: 4php echo $row Recordzetl['useri 


图 4-84 username 字段 绑 定 到 表单 隐藏 域 


重点 提示 : 当 用 户 输 入 的 用 户 名 不 存在 时 ， 即 记录 集 Recordsetl 为 空 时 ， 就 会 性 致 该 页 
面 不 能 正常 显示 ， 这 就 需要 设置 隐藏 区 域 。 


(12) 在 “文档 ”窗口 中 选中 当 用 户 输 入 用 户 名 存在 时 显示 的 内 容 即 整个 表单 ， 然 后 单 
击 “ 服 务 器 行为 ”面板 上 [ 填 按 钮 ， 在 弹出 的 菜单 中 ， 执 行 “ 显 示 区 域 ” 一 “如 果 记 录 集 不 
为 空 则 显示 区 域 ” 命 令 ， 则 打开 “如 果 记 录 和 集 不 为 空 则 显示 区 域 ”对 话 杠 ， 在 该 对 话 框 中 选 
择 记 录 集 对 象 为 Recordset1。 这 样 只 有 当 记 录 集 Recordsetl 不 为 容 时 ， 才 显示 出 来 。 设 置 完 
成 后 ， 单 击 “ 确 定 ” 按 钮 ， 如 网 4-85 所 示 。 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 
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图 485 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 


(13) 在 网 页 中 编辑 显示 用 户 名 不 存在 时 的 文本 “该 用 户 名 不 存在 !”， 并 为 这 些 内 容 设 
置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ” 隐 藏 区域 服务 喜 行 为 ， 这 样 当 记录 集 Recordsetl 为 空 
时 ， 显 示 这 些 文 本 ， 完 成 后 的 网 页 如 图 4-86 所 示 。 


eso 完善 密码 查询 功能 


当 用 户 在 showquestion.php 页 面 中 输入 管 案 ， 早 击 “ 提 区 ”按钮 后 ， 服 务 器 束 会 把 用 户 


名 和 密码 提示 问题 答案 提交 到 showpassword.php 页 面 中 。 
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HR mymember. php 
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1. 选 购 产 品 

2. 确 定 订购 : EREGEDESUUEZGM 
3. 网 上 付款 ORE ak RIS E 

4. 填 写 信 息 : 


Qo <table> DG (RIM Q 100& v T5 x 403v 8T K / 2 P Unicode OF-6) 
4-86 ix Ec DX 
下 面 介绍 如 何 设计 该 页 向 ， 有 其 体制 作 步 又 如 下 。 
(1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 showpassword. 


php 的 网 页 并 保存 。 
(2) 在 Dreamweaver 中 使 用 提供 的 制作 静态 网 页 的 工具 ， 完 成 如 图 4-87 所 示 的 静态 部 分 。 


四 C: XApachekhtdocshmemberkshowpassword.php (XHTML) 


| 对 不 起 多 输入 的 符 案 不 正确 ,请 间 击 这 里 重新 输入 


| 购物 流程 


1. 选 购 产 品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 写 信息 
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R| Qj 100% — v T25 x 427v 83 K / 2# Unicode (UTF-8) 
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(30 JT. "ELI" — HE do. FTIF AWE” IB, ÉME [TT 
在 弹出 的 菜单 中 选择 “记录 集 (查询 )” 选 项 ， 则 会 打开 “记录 集 ” 对 话 框 。 

(4) 在 该 对 话 框 中 进行 如 下 设置 。 

1) 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 

2) 从 “连接 ”下 拉 列 表 框 中， 选择 数据 源 连 接 对 象 
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3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 member. 

4) 在 “ 列 ” 栏 中 选择 “ 选 定 的 ” 单 选 按钮 ， 然 后 选择 字段 列表 框 中 的 username, 
password 和 answer 等 3 个 字段 束 行 了 了 。 

5) 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 : answer 为 =， 表 单 变量 为 inputanswer, X 
示 根 据 数据 库 中 answer 字段 的 内 容 是 否 与 从 上 一 个 网 页 表单 中 的 inputanswer 表单 对 象 传递 
所 过 来 的 信息 是 否 完全 一 致 来 过 滤 记 录 对 象 。 

完成 的 设置 情况 如 图 4-88 PTR. 
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图 4-88 设置 “记录 和 集 ” 对 话 框 


(5) 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 
C6) 将 记录 集中 username 和 password 两 个 字段 分 别 添 加 到 网 页 中 ， 如 网 4-89 所 示 。 


T c:Whpachevht docsAmemberkshowpassword php (XHTML)* 


€T mymember. php 
^w, 


|| 购物 流程 


1. 选 购 产品 
2. 确 定 订购 
3. 网 上 付款 
4.385518 8. 
5. 签 收 产品 


< | lll] 
<body> «table? <tr> <td> <table> Ctr? <td> <p> DS Q, 100% ~vi T25 x 403v 86 K / 2 fh Unicode (UTF-8) 


图 4-89 加 入 的 记录 集 效 果 


(7) 同样 需要 根据 记录 集 Recordsetl 是 否 为 衬 ， 为 该 网 页 中 的 内 容 设置 隐藏 区 域 的 服务 
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器 行为 。 在 “文档 ” 寄 口 中 ， 选 中 当 用 户 输 入 密码 提示 问题 答案 正确 时 显示 的 内 容 ， 然 后 单 
击 “ 服 务 器 行为 ”面板 上 [ej 按钮， 在 弹出 的 菜单 中 ， 执 行 “ 显 示 区 域 ” 一 “如 果 记 录 和 集 不 
为 空 则 显示 区 域 ” 命 令 ， 打 开 “ 如 果 记 录 集 不 为 容 则 显示 区 域 ” 对 话 框 ， 在 该 对 话 框 中 选择 
记录 集 对 象 为 Recordset1。 这 样 只 有 当 记 录 集 Recordsetl 不 为 衬 时 ， 才 显示 出 来 ， 如 几 4-90 
所 示 。 设 置 完成 后 ， 单 击 “ 人 确定 ”按钮 ， 关 闭 该 对 话 框 ， 人 返回 到 “文档 ”窗口 。 
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4-90 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 
C8) 在 网 页 中 选择 当 用 户 输 入 密 但 提示 问题 答案 不 正确 时 显示 的 内 容 ， 并 为 这 些 内 容 设 
置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ”隐藏 区 域 服务 嚣 行为， 这样 当 记录 集 Recordsetl HE 
时 ， 显 示 这 些 文本 ， 如 图 4-91 所 示 。 
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图 4-91. “如 果 记 录 集 为 空 则 显示 区 域 ” 对 话 框 


(9) 完成 后 的 网 页 如 图 4-92 所 示 。 执 行 染 单 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 
到 本 地 站 点 中 。 
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CHAT mymember. php 


EI 


: 购物 流程 : 用 户 : (Recordsetl usemame) 


1 . 选 购 产品 | 密码 : {Recordsetl password) 
2. 确 定 订购 
3. 网 上 付款 
4. 填 与 信息 
5. 签 收 产 品 


单 击 这 里 重新 登录 


E: j > 


- — 
body? <table> Ctr? <td> Kr) R] Q 100€ v7T25 x 403v 8T K / 2 fh Unicode (UIF-8) — - 


图 4-92 ”完成 后 的 网 页 效果 图 


SQL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


用 户 管 理 系 统 开 发 


epe 测试 密码 查询 功能 


开发 完成 后 ， 就 可 以 测试 密码 查询 功能 的 执行 情况 了 。 
(1) 打开 IE 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/member/index.php， 打 开 index.php 
文件 。 单 击 该 页 面 中 的 “拷问 密码 ” 超 文 本 链接 ， 如 图 4-93 所 示 的 页 面 。 
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图 4-93 输入 要 查询 的 用 户 名 


(20 当 用 尸 进入 密 介 得 询 页 面 lostpassword.php 后 ， 输 入 并 辣 服 务 占 提交 目 己 注册 的 用 
户 名 信息 。 当 输入 不 存在 的 用 户 名 ， 并 单 击 “ 提 交 ” 按 钮 ， 则 会 转 到 showquestion.php 页 
面 ， 该 页 面 显 示 出 用 户 名 不 存在 的 错误 信息 。 
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图 4-94 输入 的 用 户 名 不 存在 


PHP 


QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(3) 如 果 输 入 一 个 数据 库 中 已 经 存在 的 用 户 名 ， 然 后 单 击 “ 提 交 ” 投 钮 。 正 Vnd H 
动 转 到 showquestion.php WH, WKI 4-95 所 示 。 下 面 就 应 该 在 showquestion.php 输入 密码 提 
不 问题 答案 ， 测 试 showquestion.php 网 页 的 执行 情况 。 


c 查询 问题 一 icrosoft Internet Explorer 加 回国 
XF MEE ”查看 0) 收藏 人 IAM) #8) 
OAE- O- NAOI kear 四 | 自 - 有 日 所 


地 址 部 ) 名 Aa dt D. D. 1/member/ showquestion. php 所 输入 关键 司 搜索 a 转 到 ”链接 o SnagIt ES 


gc 


| 购物 流程 


1. 选 购 产 品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 与 信息 


5. 签 收 产品 


^ 


ESL 
查询 问题 


:问题 提示 : 你 最 好 的 朋友 是 ? 


联想 手提 电脑 


团购 特惠 


(AD Internet 


4-95 showqeustion.php 网 页 效果 图 


(4) 在 这 里 可 以 先 输入 一 个 错误 的 答案 ， 检 杜 showpassword.php 中 是 否 能 够 显示 密码 所 
示 问 题 的 答案 不 正确 时 的 错误 信息 ， 如 图 4-96 所 示 。 


A g — Nicrosoft Internet Explorer 
AEG) mD EE REA IAM $$B500 


QsB-O-i|9iz2 (6 Dmsmk jx 6 A SBL 


地 址 部 ) &] http: //12T. 0. 0. 1/member/showpassword. php 所 输入 关键 司 搜索 ~] 转 到 “ 链接 o SnagIt ES 


fis Fox m 


| 购物 流程 


1. 选 购 产 品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 写 信 息 
5. 签 收 产品 


^ 


联系 我 们 
| 特别 推荐 


| 对 不 起 您 输入 的 答案 不 正确 ,请 单 击 这 里 重新 输入 4 


联想 手提 电脑 


(AD Internet 


图 4-96 出错 信息 


用 户 管 理 系 统 开 发 


(5) 如 果 在 showquestion.php 网 页 中 输入 正确 的 答案 ， 并 单 击 “提交 ”按钮 后 ， 浏 览 器 
就 会 转 到 showpassword.php 页 面 ， 并 显示 出 该 用 户 的 密码 来 ， 如 图 4-97 所 示 。 
DER 

L| 


SEA: 一 Nicroso ft Internet Explorer 
TFP mE ERE) 收藏 人 工具 (T) #80) 
OAE- O- NDO ka e O-R o € 


地 址 部 ) E] http: //127. D. D. 1/member/showpassword. php hc M 转 到 ”链接 © SnagIt EJ 
E ^ 


-< 


TO c 
Atg lá EIL j 


: ` E 
m. V 


P Bro 


客户 留言 联系 我 们 


| 特别 推荐 


用 户 : admin 


密码 : 111111 ~ 
联想 手提 电脑 


购物 流程 单 击 这 里 重新 登录 : - 


2 .确定 订购 : 索尼 数码 相机 
3. 网 上 付款 : : 

4. 填 写 信息 : : ba 
5. 签 收 产 品 


4-97 showpassword.php 页 面 


(60 上 述 测试 结果 表明 ， 和 密码 便 询 系统 已 经 成 功 制作 。 
全 此 ， 用 户 管 理 系统 的 利用 功能 都 已 经 设计 完成 并 测试 成 功 ， 设 计 者 如 宋 需 要 将 其 应 用 
到 其 他 的 网 站 上 ， 只 需要 与 设计 的 页 和 面 配 合 ， 修 改 一 些 相 关 的 文子 说 明 及 背景 效果 ， 束 可 以 


LA 


完成 用 户 管理 系统 的 制作 。 


A 


第 司 发 布 系统 开发 


新 闻 发 布 系统 是 动态 网 站 建设 中 经 常用 到 的 系统 ， 尤 其 是 在 政府 单位 、 教 育 单位 或 企业 
网 站 。 新 闻 发 布 系统 的 作用 就 是 在 网 上 传播 信息 ， 通 过 对 新 闻 的 不 断 更 新 ， 让 用 户 及 时 了 解 
行业 信息 、 企 业 状 况 。 所 以 新 闻 发 布 系统 中 所 涉及 的 主要 操作 就 是 访问 者 的 新 闻 查 询 功能 和 
系统 管理 员 对 新 闻 的 新 增 、 修 改 、 删 除 功能 ， 使 用 PHP 实现 这 些 功能 相对 比较 简单 。 


EB 新 


MATIE E 


主要 掌握 以 下 知识 所 : 


新 闻 发 布 系 统 网 页 结构 的 整体 设计 


新 闻 系 统 数 据 库 的 规划 

新 闻 发 布 系 统 前 台新 闻 发 布 功 能 页 面 的 制作 
新 闻 发 布 系统 分 类 功能 的 设计 

新 闻 发 布 系 统 后 台新 增 、 修 改 、 删 除 功 能 的 实现 


pO ELELEE 


= | 
| 


系统 的 整体 设计 规划 


网 站 的 新 闻 发 布 系 统 ， 在 拉 术 上 主要 体现 为 如 何 显 示 新 闻 内 容 ， 以 及 对 新 闻 及 新 闻 分 类 
的 修改 和 删除 。 一 个 完整 的 新 闻 发 布 系 统 共 分 为 两 大 部 分 ， 一 个 是 访问 者 访问 新 闻 的 动态 网 
页 部 分 ， 万 一 个 是 过 理 者 对 新 闻 进 行 编辑 的 动态 网 页 部 分 。 新 闻 发 布 系统 的 结构 岁 如 网 5-1 
所 示 。 


新 闻 发 布 系统 


index.php 
访问 者 页 面 


admin login.php admin.php 


type. add. php || type upd. php || type del. php || news add.php || news upd.php || news del.php 


图 5-1 痢 闻 发 布 系统 结构 图 
本 系统 页 面 共 有 11 个 ， 整 体系 统 页 面 的 功能 与 文件 名 称 如 表 5-1 所 示 。 


里 者 页 面 


1R 
H 


表 5-1 新 闻 发 布 系统 开发 网 页 设计 表 


需要 制作 的 主要 页 面 x 能 
新 闻 首页 显示 新 闻 分 类 和 最 新 新 闻 页 面 

浙 闻 分 类 页 面 显示 新 闻 分 类 中 的 新 闻 标题 页 面 
浙 闻 内 容 页 面 显示 新 闻 内 容 页 而 

台 管 理 入 口 页 面 管理 者 登录 入 口 页 面 

后 台 管 理 主页 面 对 新 闻 进 行 管理 的 主要 页 面 
浙 增 新 闻 页 面 增加 新 闻 的 页 面 
修改 新 闻 页 面 修改 新 闻 的 页 面 
删除 新 闻 页 面 删除 新 闻 的 页 面 

浙 增 新 闻 分 类 页 面 增加 新 闻 分 类 的 页 面 

修改 新 闻 分 类 页 面 修改 新 闻 分 类 的 页 面 

删除 新 闻 分 类 页 面 删除 新 闻 分 类 的 页 面 


页 面 设计 规划 


在 本 地 站 点 上 建立 站 点 文件 来 news， 将 要 制作 的 新 闻 发 布 系统 文件 夹 和 文件 建 并 如 


o >. WU 


PHP+ qm MÀ TETTPTTTWNREDLI. 


| 5-2 Biz. 


* C: XApacheVhtdocsVnews SA 
文件 @) MED SEV KAA IAM WOW EF 
QAE- Of Pk COXHE E 

地 址 0) |Ø C: Apachevhtdocsvnews 


文件 和 文件 夹 任 务 。 [和 】 B 区 un 


C9 创建 一 个 新 文件 来 
Q 将 这 个 文件 来 发 布 到 多 
Web 1 data 
共享 此 文件 夹 
| index. 
images Ky: PHP rb 


"m scontent.php EE o e. 


x 文件 《 [3E ne ;H 


8 THR 7.34 理 | 早 我 的 电脑 


新 闻 发 布 系 统 主要 起 到 了 宣传 的 作用 ， 实 例 中 在 色调 上 选择 更 色 和 绿色 作为 主 色调 。 由 
于 本 书 主 要 讲述 使 用 Dreamweaver 开发 PHP 的 方法 ， 所 以 网 页 的 美工 设计 相对 比较 简单 ， 
P HW index.php 效果 如 图 5-3 所 示 。 


Dw XM) c) EEM BAWO 修改 的 ERM PO MAG WOO WO | | Wt ~ CORR 


CU IET TES 
TILA JE 
sasn TAFA 


Er3 格式 了 x 


ma) x 


5-3 HEA index.php ZUR Fd 


新 闻 发 布 系统 开发 


Sectio 


数据 库 设计 与 连接 


制作 一 个 新 闻 发 布 系统 ， 首 先 要 设计 一 个 储存 新 闻 内 容 、 管 理 员 账 志和 密码 的 数据 库 文 
件 ， 方 便 管 理 人 员 对 新 闻 数 据 信 息 进 行 管理 和 完善 。 


521 | 新 闻 效 据 库 设 计 

新 闻 发 布 系统 需要 一 个 用 来 存储 新 闻 标 题 tle 和 新 闻 内 容 content 的 新 闻 信 息 表 ， 还 要 
建立 一 个 新 闻 分 类 表 和 一 个 管理 信息 表 ， 分 别 命名 为 news. newstype. admin 数据 表 。 制 作 
的 步骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL", 进入 MySQL 数据 库 的 管理 面 
板 ， 如 图 5-4 所 示 。 


i? SQL Nanager 2007 for MySQL 


Database View Tools Services Plugins Options Windows Help 
; ] : iaia ae 


- Getting Started 


S- localhost (b Create new database 
m mysal on localhost 
m Manage existing database(s) 
Database Tools 
g Execute SQL script 
e3 Manage users 
: Help and Support 


(9 SQL Manager 2007 help system 


(9 MySQL reference 


—. Internet Resources 


的 SQL Manager 2007 home page E. Support Center 


G SQL Manager 2007 on-line documentation Q SQL Manager 2007 FAQ 


5-4 打开 MySQL 数据 库 管 理 界面 


(2) 单 击 工 具 栏 的 Create. CHO 按钮 ， 并 在 打开 的 下 拉 沫 单 中 单 击 选择 “DataBase 
数据库)” 命 令 ， 如 图 5-5 所 示 。 

(3) 打开 “Create Database Wizard 〈 建 立 数 据 库 问 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
“news”。 然 后 再 单 击 Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 ， 如 图 5-6 Dr. 

(4) 设置 MySQL 数据 库 的 连接 设置 如 表 5-2 以 及 如 图 5-7 所 示 。 然 后 再 单 击 Next (下 
一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 


Create Database Wizard 


Create Database 


Specify the name for a new database 


Welcome to the Create Database Wizard! 
This wizard allows you to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SOL statement for creating the database and execute it 
on MySQL server. 


Database name news 


Register after creating 


5-5 #m "Database" fi 5-6 输入 数据 库 的 名 称 news 


表 5-2 数据 库 连 接 设 置 


User name root 


Password admin 


Create Databaze Wizard 
Create Database 


Set connection praperies For a new database 


Host name localhost v Port 3308 7 


User name ront 


— Manager 


—— forMySQL [C_| Use tunneling 
LN Tunneling 
SSH tunneling HTTF tunneling 


图 5-7 连接 设置 


(5) 打开 新 建 数 据 库 的 SQL 语句 提示 ， 创 建 数据 库 news, H Next (下 一 步 ) Ja 
钮 ， 如 图 5-8 所 示 。 

(6) Hh Finish CER) 按钮， 打开 注册 数据 库 的 设置 画面 ， 选 择 utf8 字符 集 、 人 简体 中 
文 版 的 GB2312 版 ， 其 他 的 你 持 献 认 值 ， 如 图 5-9 所 示 。 


新 闻 发 布 条 统 开发 


Create Database Wizard 
Create Database 


Hesult SOL statement. Click the Finish button to create a new database. 


Fiezult SaL statement: 
CREATE DATABASE "newz'; 


* Connection 


Display Options Host name 

[— Directories User name 
Logz 

(f$ SSH Tunneling 
HTTP Tunneling Hielo mete 


Data Options 


Password 


Database alias 


Client charset 


Font charset 


图 5-9 ”选择 简体 中 文 


CI) AROK MAA) 按钮 ， 束 完成 了 数据 库 news 的 狐 增 工作 。 

数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 分 别 是 
news、newstype、admin。 建 并 数据 表 后 ， 接 着 再 单 击 左 边 的 “Connect to Database. (连接 数 
HE” BHA 将 其 连接 上 。 这 两 张 数 据 表 的 字段 结构 内 容 说 明 如 下 。 

(1) 建立 数据 库 news 后 ， 用 鼠标 右键 单 击 选择 “Table〈 表 格 )” 选 项 ， 在 打开 的 荣 单 
中 单 击 选择 “New Table OKIE)” ME, WK 5-10 所 示 。 


IPHP+ 


# SQL Nanager 2007 for NySQL — news on localhost [news] 
Database View Tools Services Plugins Options Windows Help 


日 Q localhost 
m member on localhost 
5-H news on localhost 


òc Hr] 7 Br 


2 Getting Started 


Ek Create new database 


m Manage existing database(s) 


7 Execute SQL script 


| [93 New Tab from Here... 


Rename Current Tab.. 


Delete Current Tab 


Find Item... 


i ocalhostinews on localhost'Tables 
: Tables 


news， 如 图 5-11 所 示 。 


Ta Manage users 


p and Support 


€) SQL Manager 2007 help system 
(9 MySQL reference 


Internet Resources 


的 SQL Manager 2007 home page 


SQL Manager 2007 on-line documentation 


QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


= Create new table 


[r4 Create new database object 


区 | Execute query 


$» Manage permissions 


S Support Center 


Q SQL Manager 2007 FAQ 


5-10 ”开始 建 数 据 表 


(2) 数据 库 右 方 界 面 会 出 现 新 建 数据 表 (Table) 的 设置 区 域 ， 含 有 “Table《〈 表 格 )” 
“Fields (内 容 )”“DDL (驱动 )”3 个 选项 卡 ， 先 在 “Table (表格 )” 中 输入 数据 表 名 


a New Table — [news on localhost] 


S news on localhost [news] + 


| iF Compile 
L2 Show SL help 
国 Restore default size 


Fields | DDL 


Table Properties 


Table name news 
Storage Optionz 
Storage engine 
Row format 
Min. rows 

Max. rows 

Auto increment value 
Average row length 
Size for index key blocks 
[| Check sum 

[ ]Pack keys 


| | 
x5 
pP 
E| E 
m| Z 
一 | 

4| € 


I 
m 
pai] 

-Z 
- 
qm 

-2 
三 
x 
ES 
iD 


zj 
p] 
3 
Ea 
a 
Sa 
zn 
= 
= 


Character Sets | File Options || Merge Table Options | Federated Table Options 


Character set 


Callation 


年 
ca 
&|* 


5-11 输入 数据 表 名 news 


G) 然后 再 切换 到 “Fields 内容 )” 选 项 卡 中 ， 输 入 数据 域名 以 及 设 症 数据 域 位 的 相关 
数据 ， 如 表 5-3 及 图 5-12 Bros. 


pO ELELEE 


表 5-3 新 闻 信 息 数据 表 news 


£ Table — [news] — [news on localhost] mef) 


Object e ^l | Properties | Fields ||ndices | Triggers | Data | Dependencies | DDL 


Field Name Field Type Size Precisi... Not Null Default Comment | 
| BJ news on localhost nes v Enews id INTEGER |20 |o | m INDE 
E ems news title VARCHAR (50 0 Null 
Ez: newes type VARCHAR 20 Null 
& news_content TEXT 0 Null 
[a] Refresh news date DATE 0 Null 
学 Compile ES newes author VARCHAR 20 Null 
Qs Grants on table 


General 


[3 [SI E [SI [S] 


& Print 

©) Show SQL help 

(d Table Editor options 
回 Restore default size 


Tools 


E Truncate table 


Fields 


Sg Add new field 
ig Edit selected field 
Eg Drop selected field(s) 


Explorer 
(2-85 Fields (5) 


图 5-12 ”设置 数据 库 


(4) 同样 创建 newstype 数据 表 ， 用 于 储存 新 闻 分 类 用 ， 输 入 数据 域名 以 及 设置 数据 域 
位 的 相关 数据 ， 如 表 5-4 及 图 5-13 Br. 


表 5-4 新 闻 分 类 信息 数据 表 newstype 


(5) 创建 admin 数据 表 ， 用 于 后 台 管 理 者 登录 验证 用 ， 输 入 数据 域名 以 及 设置 数据 域 位 
的 相关 数据 ， 如 表 5-5 及 图 5-14 所 示 。 


表 5-5 管理 信息 数据 表 admin 


PHP+MySQL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


a Table — [newstypel — [news on localhost] mn 回 [x| 


Object A Properties | Fields |Indices | Triggers | Data | Dependencies | DDL 
Field Mame | Field Type Size Prec... Mot ... Defaut | Comment 


Biverme wwowm o LEI 


| le] Refresh 
学 Compile 
is Grantz on table 
gza Print 
L2 Show SOL help 
qi Table Editor options 
国 Restore default size 


5-13 ”创建 newstype 数据 表 


g Table — [admin] — [news on localhost] 回回 因 
Object 全 Properties | Fields Indices | Triggers | Data | Dependencies DDL 


Field Name Field Type Size Precis... Mot Null Default . Comment 
INTEGER 11 


| E news on localhost [ne* g 


BB admin v 


[a] Refresh 
学 Compile 
Jo Grants on table 


ca Print 

©) Show SQL help 

d Table Editor options 
加 Restore default size 


Tools 


E Truncate table 


5-14 创建 admin 数据 表 


在 创建 上 述 的 3 个 数据 表 时 ， 其 中 涉及 到 新 闻 保存 时 的 时 间 问题 ， 使 用 PHP 实现 获取 
系统 默认 即时 时 间 ， 可 以 使 用 两 种 方法 实现 ; 一 种 是 在 网 页 PHP. 中 用 date0 和 time0 函 数 实 
现 ， 另 一 种 是 直接 用 MySQL. 数据 库 中 的 NowO 时 间 。 考 虑 到 如 果 后 期 数据 量 大 减少 服务 器 
的 工作 量 ， 优 先 采 用 在 网 页 使 用 PHP 获取 时 间 的 方法 。 具 体 的 实现 方法 在 新 增 新 闻 页 面 的 
设计 时 会 讲 到 。 


JOAN 定 Xnewsi 点 OO 


在 Dreamweaver CS 5.5 中 创建 一 个 “新 闻 发 布 系统 ”网 站 站 点 news， 由 于 这 是 PHP 数 
气 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 。 主 要 的 设置 如 表 5-6 所 示 。 


452 CERISE 


45-6 站 点 设置 的 基本 参数 


站 点 名 称 news 
本 机 根 目 录 CAApacheMtdocsnews 
测试 服务 器 CAApacheMtdocsV 
网 站 测试 地 址 http://localhost/news/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All Users\Application DataNMySQLAMYyYSQL Server 5.5\datanews 
管理 账号 / 密码 root / admin 
数据 库 名 称 news 


创建 news 站 点 具体 操作 步骤 如 下 。 
(1) 首先 在 C:\Apache\htdocs 路 径 下 建立 news 文件 来， 如 图 5-15 所 示 ， 本 章 所 有 建立 
的 网 页 文件 都 将 放 在 该 文件 夹 下 。 


Capachexhtdocs PB) 
Ld 


TED REO SEV BEA IAM WEO 
QAE- O- JPs5* DHR m 


地 址 m) |Ø C: \Apachethtdocs v E55 
A 名 称 和 修改 日 期 
YfERUYTEXHES [o omnServerScripts 2011-7-6 16:06 
x BS nenber 2011-7-7 22:04 
=j EE XE PES 2011-7-8 10:40 
(Gy 移动 这 个 文件 夹 Ø rh 2011-6-15 9:41 
[D 复制 这 个 文件 来 个 phpWykdnin 2011-7-4 9:35 
Q 将 这 个 文件 到 发 布 到 了 2011-6-30 15:30 
dad B test 2011-7-6 15:55 
ka] HFHH Æ] index. html 2004-11-20 15:16 


a ETAD E t test. php 2011-7-6 8:35 
K eso TEX 


5-15 建立 站 点 文件 夹 news 


(2) 运行 Dreamweaver CS .35， 选 择 菜 单 栏 中 的 “站 点 ?” 
一 “管理 站 点 ”命令 ， 打 开 “ 管 理 站 点 ”对 话 框 ， 如 图 5-16 
所 示 。 

(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 
定义 的 站 点 。 单 击 右边 的 “ 狐 建 ”按钮 ， 打开“ 站 点 设置 对 
象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ”: news. 

“本 地 站 点 文件 来” CNApacheMtdocsnews. 

如 图 5-17 所 示 。 


5-16 “管理 站 点 ”对 话 框 


PHP+ QL-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


站 点 设置 对 锡 news 
Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Drearmweaver 


站 点 通常 包含 两 个 部 分 ; 可 在 其 中 存储 和 处 理 文 件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 支 布 到 web 上 的 服务 器 上 的 远程 文件 来 。 


您 可 以 在 此 处 泊 Dreamweaver 站 点 选择 本 地 站 件 夹 和 名 称 。 
站 点 名 称 ; 
zE Hh s c reb: | CApachethtdocsinewsl 5 


K] 5-17 建立 news 站 点 


(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [二 |， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 5-18 所 示 的 参数 设置 。 

“IRIRE”: news. 

“连接 方法 ” 本地/ 网络 。 

“服务 器 文件 来” C:\Apache\htdocs\。 

“Web URL”: http:// localhost/ news/. 


AA ROS news 


服务 器 名 称 ， 
连接 方法 
Was [Cis S 


图 5-18 设置 “基本 ”选项 卡 


(50 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 步 
信息 ” 复 选 按钮 ， 在 “服务 需 模 型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 5-19 Brzn. 


新 闻 发 布 条 统 开发 


站 点 设置 对 旬 news 


版 本 控制 
> 高 级 设置 M 锥 护 同步 信息 
口 ] 保存 时 自动 将 文件 上 传 到 服务 器 
C] 启用 交 件 职 出 功能 
[V] 打开 文件 之 前 取出 


REZE: OOO 
电子 邮件 地 址 : 


5-19 设置 “高 级 ”选项 卡 


(6) 单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 选 择 “ 测 试 ” 复 选 按钮 ， 
如 图 5-20 所 示 。 


站 点 设置 对 锣 news 

— — 

您 将 在 此 位 置 选 择 兴 载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
版 本 控制 Internet 服务 提供 商 (ISP) 或 web 管理 员 。 


* ”高 级 设置 


注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步骤 。 如 果 要 连接 到 | web 并 发 
布 页 面 ， 您 只 需 定 必 一 个 远程 服务 器 即 可 。 


名 称 | 地址 | 连接 | 远程 测试 | 
news CiApachejhtdocs 本 地 | 网 络 [V M 


5-20 设置 “服务 器 ”参数 

单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 

才 所 设置 的 站 点 news。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 了 
Dreamweaver CS 5.5 测试 新 闻 发 布 系统 网 页 的 网 站 环境 设置 。 


323 设置 数据 库 连 接 
完成 了 站 点 的 定义 后 ， 接 下 来 就 是 新 闻 发 布 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 


库 的 连接 设置 如 下 。 
(1) 将 光盘 中 本 章 文 件 复制 到 站 点 文件 夹 下 ， 打 开 index.php, WE 5-21 所 示 。 


PHP+ QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


Dw 


| aHa | E T) O cw foak 
THI SE 查看 (Y) 插入 (IT) ER AO 命令 (C) 站 点 (3) EQ 帮助 (D 


C:\Apache\htdocs\news\indez. php 


m news. pho 


T B ne 本 地 视图 w 

: HB 
Poesie D] a [3t] | ERHERS | p** [d 实时 视图 | 检查 MM O. SREI A C &elàáovag8|" 
iGo C qi x 3 


NEWS 
PHP 新 闻 系 统 


RY Q 1008  . 739 x 475v 53 K / 2 19 Unicode (VIF-8) 


BRO) |E 

E css ID(I) 无 IC 目标 (c) 
国 单元 格 KEDR TATOO FAME G) [ .| erre TERE. -— " 
E k> " c — 
cst $80! 标题 L 1 个 本 地 项 目 被 选中 ,总 


5-21 打开 网 站 首页 index.php 


(2) 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 
令 ， 打 开 “ 数 据 库 ”面板 。 在 “数据 库 ” 面 板 ， 单 击 选择 
“+ ”图标 ， 并 在 打开 的 菜单 中 选择 “MySQL Xie" up EE 
项 ,如 图 5-22 Bi. 

(3) Æ “MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 4 
称 ” 为 news, *MySQL 服务 器 ”名 为 localhost,“ 用 户 
名 ”为 root， 密 码 为 admin, JE 5-23a 所 示 。 选 择 所 要 ”图 5-22 选择 “MySQL 连接 
建立 连接 的 数据 库 名 称 ， 可 以 单 击 “ 选 取 ” 按 钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数据 库 。 选 
择 刚 建立 的 范例 数据 库 news， 有 具体 的 设置 内 容 如 图 5-23b 所 示 。 


NySQL 连接 


定 à : [book 
连接 名 称 : news db shop 
3 inf ti h 
MySQL 服务 器 : localhost 1n ber lon schema 
用 户 名 : root 


performance schemaold 
SrhH. eek 


数据 库 : news 


图 5-23 WE “MySQL 连接 ”参数 


(4) 单 击 “ 测 试 ” 按 钮 来 测试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 来 正确 则 会 出 一 个 
消息 枉 ， 如 网 5-24 所 示 ， 表 示 数 据 库 连接 设置 成 功 了 。 


C5 CIEZEUG5LLEA 


单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 和 面板 中 则 显示 绑 定 过 来 的 数据 库 ， 
如 图 5-25 所 示 。 


数据 库 


NySQL 连接 % 
DO AE *, 一 文档 类 型 : Pe isi ©) 
~A 


脚本 编制 K 
a i admin ` 


连接 名 称 : 
MySQL 服务 器 : 
用 户 名 : root 

密码 : 

数据 库 : 


图 5-24 设置 成 功 图 5-25” 绑 定 的 数据 库 


系统 页 面 设计 


狐 闻 发 布 系统 前 台 部 分 主要 有 3 个 动态 页 面 ， 分 别 是 狐 闻 主页 面 mdex.php， 新 闻 分 类 页 
而 type.php， 狐 闻 内 容 页 而 newscontent.php。 


SE 新 闻 发 布 系统 首页 设计 


在 本 小 节 中 主要 介绍 新 闻 发 布 系统 的 主页 面 index.php 的 制作 。index.php 页 面 主要 有 显 


示 最 狐 狐 闻 的 标题 、 加 入 时 间 、 显 示 新 闻 分 类 、 单 击 狐 闻 中 的 分 类 进入 分 类 子 页 面 查 看 新 闻 
等 功能 。 制 作 的 步骤 如 下 。 

(1) 打开 刚刚 创建 的 index.php Ji. WARRE "Bub. DIESE XI" 
一 “保存 ”命令 ， 将 网 页 保存 。 

(2) 用 鼠标 单 击 创建 表格 的 第 1 行 单 元 格 ， 输 入 文字 “新 闻 分 类 ”， 接 下 来 用 “ 绑 定 ” 
标签 ， 将 网 页 所 需要 的 新 闻 分 类 数据 字段 绑 定 到 网 页 中 。index.php 这 个 页 面 使 用 的 数据 表 是 
news 和 newstype， 单 击 “ 应 用 程序 ”面板 中 “ 绑 定 ”标签 上 的 | 则 按钮， 在 弹出 的 菜单 中 选 
择 “ 记 录 集 (查询 )” 选 项 ， 在 该 对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连 接 对 象 news。 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 newstype。 

4) 在 “ 列 ” 栏 中 先 选择 “全 部 ” 单 选 按 钮 。 

完成 的 设置 情况 如 网 5-26 所 示 。 

(3) 绑 定 记录 集 后 ， 将 记录 集 的 相关 字段 插入 全 index.php 网 页 的 适当 位 置 ， 如 图 5-27 
所 示 。 

(4) 由 于 要 在 index.php 这 个 页 面 中 显示 数据 库 中 所 有 新 闻 分 类 的 标题 ， 而 目前 的 设 定 
则 只 会 显示 数据 库 的 第 一 笔 数 据 ， 因 此 需要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ” 的 设置 ， 
选择 {Recordsetl.type_name} 所 在 的 行 ， 如 图 5-28 所 示 。 
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rr 
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EO | 


5-26 “记录 集 ” 对 话 框 


TC Apache ht dacsnews\inder. php* =- OX 


5-27 ”将 相应 字段 插入 全 index.php 网 页 中 


(5) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行 为 ” 面 
板 中 的 [ 则 按钮， 在 弹出 的 菜单 中 ， 选 择 “ 重 复 区 域 ” 命 
令 ， 在 打开 的 “重复 区 域 ”对 话 框 中 ， 选 中 “所 有 记录 ， 
单 选 按钮 ， 如 图 $-29 所 示 。 E 5-28 选择 要 里 复 显 未 的 一 列 

(6) 早 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 友 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 


Hu o4 uo | 记录 


© 所 有 记录 


图 5-29 设置 “重复 区 域 ” 对 话 框 


CI) 除了 显示 网 站 中 所 有 新 闻 分 类 标题 外 ， 还 要 提供 访问 者 感 兴趣 的 新 闻 分 类 标题 链接 
来 实现 详细 内 容 的 阅读 。 为 了 实现 这 个 功能 ， 首 先 要 选取 编辑 页 面 中 的 新 闻 分 类 标题 字段 ， 
如 图 5-30 所 示 。 


| 
{Recordsetl. type name]! 


图 5-30 选择 新 闻 分 关 标 题 


(8) 在 “属性 ”向 板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文 件 ” 图 标 ， 在 弹出 的 “ 选 
择 文 件 ” 对 话 框 中 ， 选 择 用 来 显示 评 细 记录 信息 的 页 面 type.php， 设 置 如 网 5-31 所 示 。 


选择 立 件 名 自 ; O THEN EBENE S 
OE 
a — — a 


(3. mmServerScripts "^5 index.php 


(3. netes T|newscontent. php 
(O) admin a7 d| type. php 
(Connections 


data 


[images 


xii E 
TFA Ti: BDÉOEPE (x) v 


i. 


相对 于 : | **| index. php 
广 站 点 定 儿 中 里 改 默 让 的 链接 相对 于 


图 5-31 选择 链接 文件 


(90 以 上 操作 ， 只 会 是 单纯 的 超级 链接 并 有 没 附 市 URL 参数 ， 因 此 要 单 击 “ 参 数 ” 按 
钮 ， 并 设置 超级 链接 要 附 市 的 URL 参数 的 名 称 与 值 。 将 参数 名 称 命名 为 id, WE 5-32a 所 
示 ， 在 设置 值 时 ， 单 击 图 5-32b 中 局 标 所 指 问 的 图 标 。 


ex 
RE: 


图 5-32 “参数 和 动态 数据 ”对 话 框 


(10) 单 击 “ 确 定 ” 投 钮 加 到 编辑 页 面 ， 主 页 面 index.php 中 新 闻 分 类 的 制作 已 经 完成 ， 
最 新 的 新 闻 显 示 页 和 面 设计 效 来 如 网 5-33 所 示 。 


b C: SApache*ht docs*newshinder. php* 


"nat news. php 
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ll | 
m: decoration? <tr> <td> <div> Ka) [RI Q 1100% — «| TT2 x 441 54 K / 2 $5 Unicode (UTF-8) 


图 5-33 rh ut cv CR E 


(11) 单 击 “应 用 程序 ”面板 群 组 中 的 “ 绑 定 ”面板 上 的 [由 按 钮 ， 在 弹出 的 菜单 中 选择 
“记录 集 (查询 )” 命 令 ， 在 弹出 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Rel 作为 该 记录 和 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 news. 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

5)“ 排 序 ” 设 置 为 news_id 降序 方式 。 

完成 的 设置 情况 如 图 5-34 所 示 。 
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d 


5-34 设置 “记录 集 ” 对 话 框 


(12) 绑 定 “记录 集 ” 后 ， 将 记录 集 的 字段 插入 全 index.php 网 页 的 适当 位 置 。 

(13) 由 于 要 在 index.php 这 个 页 面 显 示 数 据 库 中 部 分 新 闻 的 信息 ， 而 目前 的 设 定 则 只 会 
显示 数据 库 的 第 一 笔 数 据 ， 因 此 ， 需 要 加 入 “服务 器 行为 ”面板 中 的 “重复 区 域 ” 命 令 。 单 
击 选择 index.php 页 面 中 的 最 新 新 闻 标 题记 录 表 格 ， 如 网 5-35 所 示 。 


T C: XApacheVht docsknewskindez. php* 


"nat news. php 
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lll 


<table> <tr> <td> <table> <tr> <td> <table> <tr> <td> <table> Ku) [R] Q 100x 
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[5-35 单 击 选择 最 新 新 闻 标 题记 录 表 格 


(14) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 噩 行为 ”面板 上 的 外 按钮 ， 在 弹出 的 来 单 中 
选择 “重复 区 域 ” 命 令 ， 在 弹出 的 “重复 区域” 对 话 杠 中， 选择 要 重复 的 记录 条 数 〈 例 如 10 
条 )， 如 图 5-36 所 示 。 


f PHP + QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


图 5-36 选择 一 次 可 以 显示 的 记录 数 


(150 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 
了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

(160 由 于 最 新 新 闻 这 个 功能 ， 除 了 显示 网 站 中 部 分 
新 闻 外 ， 还 要 提供 访问 者 感 兴趣 的 新 闻 标 题 链接 全 详细 内 
容 来 阅读 ， 首 先 选取 文字 “得 看 ”， 如 图 5-37 HR. 图 5_-37 ”选择 新 闻 标题 “查看 ” 

(17) 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 
击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 ， 选 择 用 来 显示 详细 记录 信息 的 页 面 
newscontent. php， 设 置 如 图 5-38 所 示 。 


选择 立 件 名 自 : © 立 件 系统 站 点 根 目录 
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图 5-38 选择 链接 文件 


(18) 单 击 “ 参 数 ” 投 钮 ， 设 置 超级 链接 要 附 市 的 URL. 参数 的 名 称 与 值 。 将 参数 名 称 命 
名 为 news id, W| 5-39a 所 示 ， 在 设置 值 的 时 候 ， 单 击 几 5-39b 中 车 标 所 指 回 的 图 标 。 
(19) 单 击 “确定 ” 控 钮 回 到 编辑 页 面 ， 当 记录 集 超过 一 页 ， 束 必须 要 有 “上 一 页 ”、 


pO EELEE 


“下 一 页 ”每 按钮 或 文学 ， 让 访问 者 可 以 实现 翻 页 的 功能 ， 这 束 是 “记录 集 导 航 条 ”的 功能 。 
“记录 集 导 航 条 ”按钮 位 于 “ 捅 入 ”工具 栏 的 “数据 ”中 ， 因 此 将 “插入 ”工具 栏 由 “名 
用 ”切换 成 “数据 ”类 型 ， 单 击 “ 记 录 集 导航 条 ” [可 工具 按钮 ， 如 图 5-40 所 示 。 
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图 5-39 “参数 ”和 “动态 数据 ”对 话 框 
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图 5-40 ”选择 “记录 集 导航 条 ” 


(200 在 打开 的 “记录 和 集 导 航 条 ”对 话 框 中 ， 选 取 要 导航 条 的 记录 集 Rel 以 及 导航 条 的 
显示 方式 “文本 ”， 如 网 5-41a 所 示 。 然 后 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 
现 该 记录 集 的 导航 条 ， 如 网 5-41b 所 示 。 

21) 如 果 和 希望 看 到 总 共有 多 少 记录 ， 当 前 记录 是 第 几 条 ， 那 么 必须 插入 “记录 集 导 航 
Jus". 在 “插入 ”工具 栏 的 “数据 ”类 型 中 ， 单 击 “ 显 示 记 录 计 数 ” 工 具 按钮 出 ， 在 弹出 
的 快捷 菜单 中 ， 选 取 要 导航 状态 的 记录 集 为 Rel， 如 图 5-42a 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 
回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 状态 ， 如 图 5-42b 所 示 。 
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(22) index.php 这 个 页 面 需 要 加 入 “查询 ”的 功能 ， 这 样 新 闻 发 布 系统 才 不 会 因 日 后 数 
据 太 多 而 有 人 不易 访问 的 情形 发 生 ， 设 计 如 图 5-43 所 示 。 


El G 


图 5-43 ”查询 主题 设计 


重点 提示 : 利用 表单 及 相关 的 表单 组 件 来 制作 利用 关键 词 查询 数据 的 功能 ， 需 要 注意 如 
TRE, 

1) 图 5-43 所 示 的 内 容 都 在 一 个 表单 之 中 。 

2 )“ 查 询 主题 ”后 面 的 文本 框 的 命名 为 keyword. 

3 )“ 查 询 ”按钮 为 一 个 提交 表单 按钮 。 


(23) 在 此 要 将 之 前 建立 的 记录 集 Rel 做 一 下 更 改 ， 打 开 “ 记 录 集 ” 对 话 框 ， 并 进入 
“高 级 ”设置 ， 在 原 有 的 SQL 语法 中 ， 加 入 一 段 查询 功能 的 语法 ; 


where news, title like '?6".S key word."906' 


那么 ， 以 前 的 SQL 语句 将 变 成 如 图 5-44 所 示 。 


和 名称: 要 
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SUL: SELECT * 
FROM news 
WHERE news title like 'X". keyword. "& 
ORDER BY mews id DESC 


表格 ERE SOL: 
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图 5-44 修改 SQL 语句 


重点 提示 : 其 中 like 是 模糊 查询 的 运算 子 ，% 表 示 任 意 字符 ， 而 keyword 是 个 变量 ， 分 
别 代表 关键 词 。 


(240 切换 到 代码 设计 窗口 ， 找 到 Rel 记录 集 相 应 的 代码 并 加 入 代码 : 


$keyword-$ POST[keyword]; /定义 keyword 为 表单 中 "keyword" 的 请 求 变 量 ， 如 网 5-45 
所 示 ， 完成 设置 。 
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(25) 以 上 的 设置 


<?php require once('Connections/news.php'): 


;ievword-s ' [5 ;ievworc H 
if (!function exists("GetSQLValueString")) { 
function GetSQüLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "" 
{ 
if (PHP VERSION < 6) { 
$theValue = get magic quotes gpcí() ? stripslashes($theValue) : $theValue; 
} 


$theValue = function existsí("mysql real escape string") ? mysql real escape string($theValue) : 


mysql escape string($theValue); 


switch ($theType) { 

case "text": 
$theValue = ($theValue !- "") ? "'" , $theValue . "'" ; 7 
break; 

case "long": 

case "int": 
$theValue = ($theValue !- ""j ? intval($theValue) : 
break; 

case "double": 
$theValue = ($theValue !- "") ? doubleval($theValue) : " 
break; 


5-45 ”加 入 代码 
完成 后 ，index.php 系统 主页 和 面 束 有 查询 功 能 了 ， 先 在 数据 库 中 加 入 两 


条 新 闻 数 据 ， 可 以 按 下 《F12〉 键 至 浏览 右 测 试 一 下 是 否 能 正确 地 查询 。 首 先 index.php 页 面 
全 显示 所 有 网 站 中 的 新 闻 分 类 主题 和 最 新 新 闻 标题 ， 如 图 5_46 所 示 ， 


d 新 闻 首 页 =- 


Nicrosoft Internet Explorer 
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5-46 ”主页 面 浏览 效果 


(260 然后 在 关键 词 中 输入 “测试 ”并 单 击 “ 合 询 ”按钮 ， 结 来 会 发 现 页 面 中 的 记录 
只 显示 “测试 ”所 发 表 的 最 新 新 闻 主 题 而 已 ， 这 样 得 询 功 能 就 已 经 完成 了 ， 效 果 如 图 5-47 
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5 狐 闻 分 类 页 面 设 计 


狐 闻 分 类 页 面 type.php 用 于 显示 每 个 新 闻 分 类 的 页 面 ， 当 访问 者 单 击 index.php 页 面 中 
的 任何 一 个 新 闻 分 类 标题 时 就 会 打开 相应 的 新 闻 分 类 页 面 ， 新 闻 分 类 页 面 设计 效果 如 图 5-48 
所 示 。 
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图 5-48 新 闻 分 关 页 面 效果 


详细 的 操作 步骤 说 明 如 下 。 

(10 执行 染 单 “文件 ”一 “ 痢 建 ”命令 创建 新 页 向 ， 和 输入 网 页 标题 “新 闻 分 关 ”， 执 行 
菜单 “文件 ”一 “保存 ”命令 ， 在 站 点 news 文件 夹 中 将 该 文档 保存 为 type.php。 

(2) 新 闻 分 类 页 面 和 首页 面 中 的 议 态 页 面 设计 差不多 ， 在 此 不 做 证 细 说 明 。 

(3) type.php 这 个 页 面 主要 是 显示 所 有 新 闻 分 类 标题 的 数据 ， 所 使 用 的 数据 表 是 news, 


单 击 “ 绑 定 ”面板 中 的 “增加 ”上 的 图 按钮 ， 在 弹出 的 菜 音 中， 选择“ 记录 集 〈 碍 询 )” 选 


项 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 


1) 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 
2) 从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连接 对 象 news. 
3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 news。 


4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮。 


选 ” 的 条 件 为 : news_id=URL 参数 : id. 


“排序 ”方法 为 以 news_id 升序 。 


再 单 击 “确定 ”按钮 后 ， 束 完成 设 定 了 ， 如 图 5-49 所 示 。 
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5-49 ”设置 “记录 和 集 ” 对 话 框 


(4) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬入 至 type.php 网 页 中 的 适当 位 置 ， 如 图 5-50 
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5-50 ”记录 集 字 段 插入 至 type.php 网 页 中 
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(50 为 了 显示 所 有 记录 ， 需 要 加 入 “服务 器 行为 ”面板 中 的 “重复 区 域 ”命令 。 单 击 
type.php 页 面 中 需要 重复 的 表格 ， 如 图 5-51 Joa. 


10095 (511) = 
8096 (408) = 


2036 (102) = — | D 
TE v 
图 5-51 单 击 选 择 要 重复 显示 的 表格 


(6) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 内 按钮 ， 在 弹出 的 染 单 
H, WFE EEK” ME, 打开“ 重复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 数据 为 10 条 ， 如 
图 5-52 所 示 。 


: hd 


Mp 7T5 © 10 记录 
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所 有 记录 


K|5-52 ”选择 一 次 可 以 显示 的 记录 数 


CI) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 
一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

(8) 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 币 副 工具 按钮 ， 打 开 “ 记 录 和 集 导 航 条 ”对 话 框 ， 
在 打开 的 对 话 框 中 ， 选 取 Recordsetl 记录 集 以 及 导航 条 的 显示 方式 为 “文本 ”如 网 5-53a 所 
示 ， 然 后 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 网 5-53b 
PI. 
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b) 
图 5-53 添加 “记录 集 导 航 条 ” 


(9) 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 | 草 工 具 按钮 ， 在 弹出 的 菜单 中 ， 选 取 要 导航 
状态 的 记录 集 为 Recordset1， 如 图 5-54a 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 
现 页 面 出 现 该 记录 集 的 导航 状态 ， 如 图 5-54b 所 示 。 
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图 5-54 添加 “记录 集 导 航 状 态 ” 
C100 选取 文字 “详细 内 容 ” 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文 
件 ” 图 标 ， 在 弹出 的 “选择 文件 ”对 话 杠 中， 选择 用 来 显示 详细 记录 信息 的 页 面 
newscontent.php， 设 置 如 图 5-55 所 示 。 
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5-55 ”选择 链接 文件 


Jt 全 


(11) 单 击 “参数 ”按钮 ， 设 置 超级 链接 要 附带 的 URL. 参数 的 名 称 与 值 。 将 参数 名 称 命 
名 为 news id, "Kl 5-56a 所 示 ， 在 设置 值 的 时 候 单 击 图 5-56b P EITI IRL HER 
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帮助 OD :|€?php echo $row Rel['news id']; * 


5-56 “参数 ”和 “动态 数据 ”对 话 框 
(120. 加 入 显示 区 域 的 设 定 。 衣 先 选取 记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 网 5-57 所 示 。 


记录 {Recordsetl_first} 到 {Recordsetl_ last] (总 共 [Recordsetl total] ) 


5-57 ”选择 要 显示 的 表格 


d3) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 染 单 
中 ， 选 择 “ 显 示 区 域 / 如 果 记 录 集 不 为 空 则 显示 区 域 ” 命 令 ， 打 开 “ 如 果 记 录 集 不 为 空 则 显 
示 区 域 ” 对 话 框 。 在 “记录 集 ” 中 选择 Recordsetl, An] 5-58a 所 示 ， 青 单 击 “确定 ”按钮 
回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 一 个 “如 果 符 合 此 条 件 则 显 
示 ” 的 灰色 卷 标 ， 这 表示 已 经 完成 设置 ， 如 图 5-58b 所 示 。 


MI ICOK SEA 29 7B ER 


A CCusacheMatdoes Ver trpe. phos 


1 


à 
Í 记录 (Reconiset! Fustkecord] D) (Recosdest! Laetiaecosd) (E (Recordert! TotalRaconie}) 
BD 


| 


.- 
Bebo Hesse Henn Medo DSL [V] Q o-oo ws w/e vie nr | 
b) 


5-58 “记录 集 不 为 裤 ” 则 显示 


7PHP-^ 


C14) 输入 “对 不 起 ， 此 新 闻 分 类 中 没有 任何 新 闻 ” 说 明文 字 ， 同 时 选取 记录 集 没 有 数 
据 时 要 显示 的 数据 表格 ， 如 图 5-59 所 示 。 


5-59 ”选择 没有 数据 时 显示 的 区 域 


(155 单 击 “应 用 程序 ”和 面板 群 组 中 的 “服务 器 行为 ”和 面板 上 的 加 按钮 ， 在 弹出 的 末 早 
中 ， 选 择 “ 显 示 区 域 / 如果 记 录 集 为 空 则 显示 区 域 ” 人 命令， 在 “记录 集 ” 中 选择 
Recordset1， 如 图 5-60a 所 示 ， 再 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显 
示 的 区 域 左 上 角 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 着 标 ， 这 表示 已 经 完成 设置 ， 
效果 如 图 5-60b 所 示 。 
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b) 
图 5-60 “记录 集 为 空 ” 则 显示 


到 这 里 ， 新 闻 分 类 页 面 type.php 的 设计 与 制作 就 已 经 完 


新 闻 内 容 页 面 newscontentphp 用 于 显示 每 一 条 新 闻 的 详细 内 容 ， 这 个 页 面 设计 的 重点 


在 于 如 何 接收 主页 面 index.php 和 type.php 所 传递 过 来 的 参数 ， 并 根据 这 个 参数 显示 数据 库 
中 相应 的 数据 。 新 闻 内 容 页面 的 页 面 设计 效果 如 网 5-61 所 示 。 

详细 操作 步骤 如 下 。 

(1) 执行 荣 单 “ 文 件 ” 一 “新 建 ” 命 令 ， 创 建新 页 面 ， 执 行 荣 单 “ 文 件 ” 一 “保存 ” 命 
令 ， 在 站 点 中 news 文件 来 中 将 该 文档 保存 为 newscontent.php. 


QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 
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PHP 新 闻 系 统 


最 新 新 闻 司 学 录 EKE 网 络 开 发 个 人 简介 


新 闻 标 题 : 网 站 开通 了 加 六 时 间 : 2011-07-10 
新 闻 内 容 : 网 站 开通 了 ， 欢迎 访问 
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图 5-61 新闻 内 容 页 面 设计 效果 图 
(2) 页 面 设计 和 前 面 的 页 面 设计 差不多 ， 效 果 如 图 5-62 所 示 。 
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图 5-62 新闻 内 容 页 面 设 计 


(3) 单 击 “ 绑 定 ” 面 板 中 的 “增加 ”上 的 外 按 钮 ， 在 弹出 的 菜单 中 选择 “记录 集 〈 得 
询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 

1) 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连 接 对 象 news。 

3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 news。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

5) 设置 “筛选 ”的 条 件 为 : news_id =URL 参数 : news id. 

再 单 击 “ 人 确定” 按钮 完成 设 定 ， 如 图 5-63 所 示 。 


PHP+ QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 
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news content 
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5-63 ”设置 “记录 集 ” 对 话 框 


(4) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬入 至 newscontentphp 页 面 中 的 适当 位 置 ， 这 样 
束 完 成 了 新闻 内 容 页 耐 newscontent.php 的 设置 ， 如 图 5-64 PTR. 


中 | C:\Apache\htdocs\news\newscontent. php* = me: 


HEIRED news. php 
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5-64 ”将 相应 子 段 插入 全 新 闻 内 容 页 和 面 
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闻 内 容 和 新 闻 的 类 型 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 登 录 系 统管 理 入 口 页 面 的 设 
计 效 果 如 图 5-65 所 示 。 


新 闻 发 布 系统 开发 
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5-65 系统 管理 入 口 页 面 


随员 管理 入 口 页 面 


后 侣 管理 主页 面 必 须 受 到 权限 管理 ， 可 以 利用 登录 账号 与 密码 判别 是 否 为 有 效用 户 来 实 
现 权 限 的 设置 管理 。 

详细 操作 步骤 如 下 。 

(1) 执行 业 单 “文件 ”一 “新 建 ” 命 令 ， 创 建新 页 面 ， 输 入 网 页 标题 “管理 员 登 录 ”， 
执行 菜单 “文件 ”一 “保存 ”命令 ， 在 站 点 news 文件 夹 中 的 admin 文件 夹 中 将 该 文档 保存 
为 admin_login.php。 

(2) 执行 菜单 “插入 记录 ”一 “表单 ”一 “表单 ”命令 ， 插 入 一 个 表单 。 

(3) 将 光标 放置 在 该 表单 中 ， 执 行 染 单 “ 插 入 记录 ”一 “表格 ”命令 ， 打 开 “ 表 格 ” 对 
话 框 ， 在 “ 行 数 ”文本 框 中 ， 输 入 需要 插入 表格 的 行 数 4。 在 “ 列 数 ” 文 本 框 中 ， 输 入 需要 
插入 表格 的 列 数 2。 在 “表格 宽度 ”文本 框 中 ， 输 入 400 像素 ， 其 他 参数 保持 默认 值 ， 如 
图 5-66 所 示 。 


行 数 5: 
表格 宽度 : ES 
边框 粗细 : [0 ER 
单元 格 边 距 : [0 | 
单元 格 间距 : 0 B 
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5-66 设置 “表格 ”对 话 框 参数 
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(4) 单 击 “ 人 确定” 按钮 ， 在 该 表单 中 插入 了 一 个 4 行 2 列 的 表格 ， 选 择 表格 在 “属性 ” 
面板 中 ， 设 置 “ 对 齐 方式 ”为 “居中 对 齐 ”。 拖 动 鼠 标 选 择 第 1 行 表 格 所 有 单元 格 ， 在 “ 属 
性 ”面板 中 单 击 国 按钮 ， 将 第 1 行 表格 合并 。 用 同样 的 方法 把 第 4 行 合 并 。 

(5) 在 该 表单 中 的 第 1 行 中 输入 文字 “新 闻 后 台 管 理 中 心 ”” 在 表格 的 第 2 行 第 1 个 单 
元 格 中 输入 文字 说 明 “ 账 号 :” 在 第 2 行 表格 的 第 2 个 单元 格 中 单 击 “ 文 本 域 ” 按 钮 回 ， 插 
入 单行 文本 域 表 单 对 象 ， 定 义 文本 域名 为 username。“ 文 本 域 ” 属 性 设置 如 图 5-67 所 示 。 


属性 
O 如 本 域 字符 宽度 | | 类 型 Ofe Osa OET BOX v 
RETHER| | 初始 仁和 IJ | | 多 
[ ]&EFH Q9 
[]Ri& G) 


5-67 username“ 文 本 域 ” 的 属性 设置 
(6) 在 第 3 列表 格 的 第 1 个 单元 格 中 ， 输 入 文字 说 明 “ 密 码 :”， 在 第 3 列表 格 的 第 2 个 
单元 格 中 单 击 “文本 域 ” 投 钮 回 ， 插 入 单行 文本 域 表 单 对 象 ， 定 义 文 本 域名 为 password. 
“文本 域 ” 属 性 设置 如 网 5-68 所 示 。 


属性 
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5-68 password“ 文 本 域 ” 的 设置 
CI) 单 击 选择 第 4 行 蛙 元 格 ， 执 行 两 次 亲 单 “插入 记录 ”一 “表单 ”一 “ 投 钮 ”命令 ， 
插入 两 个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ” 选 
项 ， 夯 一 个 为 “ 重 设 表单 ”选项 ， 其 属性 设置 及 效果 如 图 5-69a、b、c 所 示 。 


属性 
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人 〇 重 设 表单 M 
a) 
属性 
| zd Ev) 动作 〇 提交 表单 6) OFW aS (C) 
GO 重 设 表单 M) 
b) 


TIAA A EIEH G 
PaT | 


JEN | 


c) 
图 5-69 设置 按钮 名 称 的 属性 及 效果 
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(8) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 因 按 钮 ， 在 弹出 的 菜单 
中 选择 “用 户 身份 验证 /登录 用 户 ”命令 ， 打 开 “ 登 录用 户 ”对 话 框 ， 设 置 为 如 果 不 成 功 将 
返回 主页 面 index.php， 如 果 成 功 将 登录 后 台 管理 主页 面 admin.php， 如 图 5-70 所 示 。 


从 表单 获 职 输入 : [formi 区 ` 
用 户 名 字段 : username 
密友 字段: p assword 


使 用 连接 验证 : news 

表格 : | admin 
用 户 名 列 : username 
密码 列 : | password 


如 果 登 录 成 功 ， 转 到 |: admin. php pls... 


[] 转 到 前 一 个 URL 如 果 它 存在 ) 
如 果 登 录 失 败 ， 转 到 : | . . /index. php pls... 


基于 以 下 项 限制 访问 : © 用 户 名 和 密码 
〇 有 ”用户 名 、 密 码 和 访问 级 别 
获取 级别 自 : ;1 


图 5-70 设置 “登录 用 户 ” 对 话 框 


(9) 执行 荣 单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 。 单 击 “ 行 为 ”面板 中 的 外 
按钮 ， 在 弹出 的 菜 蛙 中， 选择 “检查 表单 ”命令 。 打 开 “ 检 查 表 单 ” 对 话 框 ， 设 置 username 
和 password 文本 域 的 “ 值 ” 都 为 “必需 的 ”， “可 接受 ”为 “任何 东西 ”如 图 5-71 所 示 。 


input "username" (R) | 
input "password" (R) 
域 : 


值 : 必需 的 


可 接受 : ”任何 东西 O 数字 
O 电子 邮件 地 址 〇 数字 从 “| 到 | | 


图 5-71 “检查 表单 ”对 话 框 


单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 完 成 后 台 管 理 入 口 页 面 admin_login.php 的 设计 与 
制作 。 


百人 台 管 理 主页 面 是 管理 员 在 登录 页 面 验证 成 功 后 所 登录 的 页 面 ， 这 个 页 面 可 以 实现 新 


增 、 修 改 或 删除 新 闻 内 容 和 新 闻 分 类 的 内 容 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 页 面 
结构 如 图 5-72 所 示 。 
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新 闻 后 台 管理 中 心 ; : HESI HPR] 
添加 新 闻 

添加 新 闻 分 类 

管理 员 你 好 ?请 你 管理 新 闻 分 类 ， 
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5-72. 后 台 管 理 主 页 面 效 果 图 


详细 操作 步骤 如 下 。 

(1) 打开 admin.php 页 面 ,，( 此 页 面 设计 比较 简单 ， 页 面 设计 在 此 不 做 说 明 )， 单 击 “ 绑 
定 ” 面 板 上 的 [按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 )” 命 令 ， 在 “记录 和 集 ”对 话 
框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Re 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 news. 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

5)“ 排 序 ” 设 置 为 news_id 降序 方式 。 

完成 的 设置 情况 如 图 5-73 所 示 。 


am: 
表格 
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5-73 ”设置 “记录 集 ” 对 话 杠 
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(2) 绑 定 记录 集 后 ， 将 Re 记录 集中 的 news title 字段 插入 全 admin.php 网 页 中 的 适当 位 
置 ， 如 图 5-74 所 示 。 
E] C: hpachevht docs\news\admin\admin. php* SE 
p 新 闻 系 统 A. ii 


10096 (430) 
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5-74 记录 集 的 字段 插入 至 admin.php 网 页 中 


(3) 由 于 要 加 入 “重复 区 域 ”命令 ， 所 以 首先 选择 需要 重复 的 表格 ， 如 图 5-75 所 示 。 


5-75 ”选择 重复 的 表格 


(4) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 喜 行 为 ”面板 上 的 四 按钮 ， 在 弹出 的 深 单 
F, A ERKE” MS, 打开“ 重复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 数据 为 10 条 记 
录 ， 如 图 5-76 所 示 。 


5-76 选择 记录 集 显 示 的 记录 数 


(5) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

(6) 在 “搬入 ” 栏 的 “数据 ”类 型 中 ， 单 击 | 副 工具 按钮 打开 “记录 集 导 航 条 ”对 话 框 ， 
选取 Re 记录 集 以 及 导航 条 的 显示 方式 ， 如 图 5-77a 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 回 到 编辑 
页 面 ， 会 发 现 页 面 出 现 该 记录 和 集 的 导航 条 ， 如 图 5-77b Hrs. 
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b) 
图 5-77 添加 “记录 集 导航 条 ” 


(7) admin.php 是 提供 省 理 员 链 接 公 新闻 编 辑 的 页 面 ， 然 后 进行 新 增 、 修 改 与 删除 等 操 
作 。 设 置 了 4 个 链接 ， 各 链接 的 设置 如 表 5-7 Bron 


d 5-7  admin.php 页 面 的 链接 设置 


名 称 链接 页 面 
标题 字段 {re_news_title} newscontent.php 
添加 新 闻 news_add.php 

修改 news upd.php 

删除 news del.php 


重点 说 明 : 其 中 “标题 字段 fre_news titlej”、“ 修 改 ” 及 “删除 ”的 链接 必须 要 传递 参 
数 给 转 到 的 页 面 ， 这 样 转 到 的 页 面 才 能 够 根据 参数 值 而 从 数据 库 将 某 一 笔 数 据 筛 选 出 来 再 进 
行 编辑 。 

(8) 首先 选取 “添加 新 闻 ”， 在 “属性 ”面板 中 将 它 链 接 到 admin 文件 夹 中 的 news. add. 


php Jil. 

(9) 选取 右边 栏 中 的 “修改 ”文字 ， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 
news upd.php, ix Ell 5-78 所 示 。 


新 闻 发 布 条 统 开发 


站 点 根 目录 


E 
«| Od em 


选择 文件 名 自 : GO 文件 系统 
〇 数据 源 


查找 范围 I: O admin 


(C3. notes ^5 type add. php 
Kl admin. php 75 type del.php 
Kl admin login. php 75 type upd.php 
ic news add.php 
new s_del. php 


news_upd. php 


文件 名 OD: 
文件 类 型 CD: 


news_upd. php 


所 有 文件 ex) 


URL: | news_upd. php 
相对 于 : PES v 
在 站 点 定 必 中 更 改 默 认 的 链接 相对 于 


admin. php 


5-78 选择 链接 文件 


(100 单 击 “ 参 数 ” 控 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 将 参数 名 称 命 
名 为 news_id， 如 图 5-79a 所 示 。 在 设置 值 的 时 候 单 击 图 5-79b 中 孔 标 所 指 问 的 图 标 。 


C= 
取消 
EIN 


news title 
news type 
news content 
news date 
news author 


(i= 
ELM 


news id 


v 


: <?php echo $row Re['news id ]; ?. 


b) 
“参数 ”和 “动态 数据 ”对 话 杠 


5-79 


(11) 选取 “删除 ”文子 并 重复 上 面 的 操作 ， 要 转 到 的 页 面 改 为 news_del.php， 并 传递 


新 闻 标 题 的 ID 参数 ， 如 图 5-80 所 示 。 


站 点 根 目录 


站 点 和 服务 器 ... 


选择 文件 名 自 : GO 文件 系统 
O eis 
Q 2 p 


查找 范围 0): | C) ainin Y 


.notes 
司 adnin. php 


*5 admin login. php *5 type upd. php 
^ news add.php 
geil news_del. php 


gil news_upd. php 


*5 type add. php 
*5 type del.php 


Xt: 
文件 类 型 (T): 


URL: 


news_del. php 


PRATILI x) m 


news del.php?news id-X?php echo $row Re[' 


相对 于 : 


wrt v| admin. php 


在 站 点 定义 中 更 改 默 认 的 链接 相对 于 


5-80 ”设置 传递 全 news_del.php 
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(12) 再 选取 标题 字段 {Re_news_title} 并 重复 上 面 的 操作 ， 要 前 往 的 细 贡 页 面 改 为 
newscontent.php， 并 传递 狐 闻 参数 ， 如 图 5-81 Br. 


选择 文件 名 自 : (Gres lalis 


MI wh cesa... 


sHHED[Os — Morem 


index. php 


i  mmserverscripts 
(Cj nates ynewscontent. php 
[C admin d| type. php 
[jCennecti ons 


ic data 


[Cj images 


T 
T 


URL: ..fnewscontent.php?news id-Z?php echo fr: 


相对 于 : FE ** | admin. php 
£p Sh e xE S P ECEABAT 


图 5-81 设置 传递 全 newscontent.php 


(13) 单 击 “ 确 定 ” 按 钮 ， 完 成 转 到 详细 页 面 的 设置 。 人 至 此 ， 已 经 完成 了 新 闻 内 容 的 编 
辑 ， 现 在 来 设置 一 下 新 闻 分 类 。 单 击 “ 绑 定 ” 面 板 上 的 办 按钮， 在 弹出 的 肖 音 中， 选择 “ 记 
录 集 (查询 )” 命 令 ， 在 “记录 和 集 ”对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Rel 作为 该 记录 集 的 名 称 

2) 从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连 接 对 象 news。 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 newstype。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

完成 的 设置 情况 如 图 5-82 所 示 。 


x: © E O 选 定 的 : 


we. — 
v. — 


图 5-82 设置 “记录 和 集 ” 对 话 框 
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(14) 绑 定 记录 集 后 ， 请 将 Rel 记录 集中 的 type name 字段 插入 至 admin.php 网 页 中 的 


四 C:\Apache\htdocs\news\admin\admin. php 2 EIX 


€T news. php 
: PAPE 
H ` 


个 人 简介 


: 

: 

yp nare) M [ER] DR] o: 
: 3 

z ^ 

2 ^ 


JEREBMSX hit? PR 2010-2011 


Y 
< i | E 
d> table? <tr> <td> <table> <tr> <td> <table> <tr> <td> [R | Q 1008 vv T15 x 417v 59 K / 2 f^ Unicode (UIF-8) — - 


5-83 ”插入 相应 字段 至 admin.php 网 页 中 


(150. WMA “RERAN” P ERK” ME, Debes WME 5-84 Bp. 


图 5-84 选择 要 重复 的 表格 


(160 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 载 行为 ”面板 上 的 外 按钮 ， 在 弹出 的 沈 单 
中 ， 和 选择“ 重复 区 域 ” 命 令 ， 打开 “重复 区 域 ”对 话 框 ， 设 定 一 页 显示 的 数据 为 “所 有 记 
3x", 如 图 5-85 所 示 。 
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所 有 记录 


EE 
Tue . 


Ó 
© 


5-85 ”设置 “重复 区 域 ” 对 话 框 


C17) 单 击 “确定 ”按钮 问 到 编辑 页 面 ， 会 发 现 先 前 所 选取 要 重复 的 区 域 堪 上 角 出 现 了 
一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

(180 首先 选取 左边 栏 中 的 “修改 ”文字 ， 选 择 admin 文件 夹 中 的 type upd.php 链接 并 
传递 type id 参数 ， 如 图 5-86 Pros. 


f PHP + QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


选择 文件 名 自 : Orta ENS a 


ERIE: [Osmin — à303à3032 vor 


(C3. notes T] type add. php 
gc admin. php Tl type_del. php 


admin login. php 75 type upd. php 


J news_add. php 
dJ news_del. php 
T news_upd. php 


xi 0n 
TFN QT: PPAT Oe) v 


URL: type upd.php?type id-Z?"php echo $row Rel 


相对 于 : FE **| admin.php 
TE E S P BETERLABSgEROEECHET- 


图 5-86 设置 传递 全 type_upd.php 


(19) 选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 前 往 的 细节 页 面 改 为 type_del.php， 并 传 
递 type id 参数 ， 如 图 5-87 所 示 。 


选择 立 件 名 自 ; OTHERS IS SEHR 
DEAE 


seto: Das ë x OP 
(C3. notes "type add. php 
T] admin. php dJi type_del. php 

地 | admimr login. php Mhl type_upd. php 

dJ news_add. php 

d news_del. php 


D news_upd. php 


me 
TFN T): PPAT i.) v 


URL: type del.php?type id php echo $row Rel 


相对 于 : Arg **| admin. php 
TEX mE M p EAA EAT 


图 5-87 设置 传递 全 type_del.php 


(200 再 选取 “添加 新 闻 分 类 ”， 在 “属性 ”面板 中 将 它 链接 到 admin 文件 夹 中 的 type_ 
add.php 页 面 。 

OD 后 台 管理 页 面 是 管理 员 在 后 台 管理 入 口 页 面 admin, login.php 输入 正确 的 账号 和 密 
码 才 可 以 进入 的 一 个 页 面 ， 所 以 必须 设置 限制 对 本 页 的 访问 功能 。 单 击 “ 应 用 程序 ”面板 群 
组 中 “服务 器 行为 ”面板 中 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “用 户 吴 份 验证 /限制 对 页 的 
访问 ”选项 ， 选 择 “ 限 制 对 页 的 访问 ”命令 ， 如 图 5-88 Pr. 
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图 5-88 ”选择 “限制 对 页 的 访问 ”命令 


(22) 在 打开 的 “限制 对 页 的 访问 ”对 话 框 中 的 “基于 以 下 内 容 进 行 限制 ”选择 “用 户 
名 和 和 密码” 如 来 访问 锌 拒绝 ， 则 转 到 首页 index.php, WE 5-89 所 示 。 


基于 以 下 内 容 进行 限制 : © ”用户 名 和 密码 
O ”用户 名 、 密 码 和 访问 级 别 
选 职级 别 : 


如 果 访问 被 拒绝 ， 则 转 到 : |.. /index. php 


图 5-89 设置 “限制 对 页 的 访问 ”对 话 框 
单 击 “ 人 确定” 按钮 ， 束 完成 了 后 台 管 理 主页 面 admin.php 的 制作 。 


狐 增 新 闻 页 面 news add.php 设计 的 页 面 效果 如 图 5-90 所 示 ， 主 要 是 实现 插入 新 闻 的 
功能 。 详 细 操 作 步 骤 如 下 。 


(1) 创建 news add.php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 国 按 钮 ， 在 弹出 的 菜单 中 ， 选 


择 “ 记 录 集 《得 询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 图 5-91 所 示 的 设 管 。 

(2) 绑 定 记录 集 后 ， 单 击 “ 痢 闻 分 关 ” 的 列表 菜单 ， 在 “新 闻 分 类” 的 列表 沫 单 属 性 面 
Bop, Habe as. 按钮 ， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 进行 相关 设置 ， 如 图 5-92 
所 示 。 


PHP 


T C: XApachehhtdocsknews*hadminknews add. php* 
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图 5-90 新 增 新 闻 页 面 设计 


E Recordeet] | 
ER 0 — v[EX-] 


Minewztvpe 


x9 em O wem: 


tvpe id 
type name 


wa E — —] 
um Er | 


5-91 设置 “记录 集 ” 对 话 框 


动态 列表 / 羔 单 


: |"news type" 在 E “formi” — 
SEED ESI (4) (v) 


玉 自 记录 入 的 进项 [Recorase v 
m: [ma v 


mE: [meam | 


选 职 值 等 于 :| 《?php echo $row Recordsetl[!| 到 


5-92 设置 “动态 列表 /菜单 ”对 话 框 
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G) 本章 中 的 一 个 技术 重点 就 是 要 使 用 PHP 实现 目 动 获取 系统 的 鸭 认 时 间 ， 当 插入 新 
闻 时 能 目 动 生成 当时 的 时 间 。 方 法 是 绑 定 一 个 隐藏 字 段 并 命名 为 news_date， 切 换 到 代码 行 
KERE P: 
«input name-"news date" type="hidden" id2"news date" valuez"«?php 
date default timezone  set( Asia/Shanghai); 
echo date(" Y-m-d"); 


79>"> 


// 设 置 时 间 格 式 和 时 间 区 域 
(4) iF “M” TZE, Æ news add.php 编辑 页 面 ， 再 次 单 击 “ 应 用 程序 ”面板 群 组 
中 “服务 器 行为 ”面板 上 的 国 按 钮 ， 在 弹出 的 菜 蛙 中， 选择 “插入 记录 ”命令 ， 如 图 5-93 
所 示 。 
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5-93 选择 “插入 记录 ”选项 
(5) 在 “插入 记录 ”的 设 定 对 话 框 中 ， 输 入 如 图 5-94 所 示 内 容 。 


RTA. B: a 
连接 : news 
插入 表格 : news 


'news id 是 一 个 -未 使 用 的 主键 。 

"news tue j " FORM. news. title d S Ld 
'news type 从 ! rm news type BEBE Er 

j news cont ent 从 FORM. news cont ent’ 获 职 值 作为 pur x 
'news date! M’ FORM. news date' 获取 值 作 洲 ， 日 期 
'news | author’ 从 'FORM. news _author” 获 职 值 作为 “ 交 本 * 


1B: 无 (Nj 
REN: x 


插入 后 ， 转 到 : |admin. php 


5-04 设置 “插入 记录 ”对 话 杠 


A PHP-* 


(6 执行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ”面板 上 的 国 
按钮 ， 在 打开 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 。 打开“ 检查 表单 ”对 话 框 ， 设 置 值 都 为 
“必需 的 ”“ 可 接受 ”为 “任何 东西 ” 如 图 5-95 Bran. 


"news ti iode , RJ 
Dl — 


(à: 必需 的 


可 接受 : 名 ”任何 东西 O 数字 
O 电子 邮件 地 址 O 数字 人 | | 到 | | 


图 5-95 设置 “检查 表单 ”对 话 框 
单 击 “确定 ”按钮 回 到 编辑 页 面 ， 束 完成 news_add.php 页 面 的 设计 了 。 


SO eam 


修改 新 闻 页 面 news upd.php 的 主要 功能 是 将 数据 表 中 的 数据 送 到 页 面 的 表单 中 进行 修 


改 ， 修 改 数 据 后 再 将 数据 更 新 到 数据 表 中 ， 页 面 设计 如 图 5-96 所 示 。 


TC: \hpache\ht docsNnewsVadminknews upd. php EIE 
管理 员 ， 你 好 请 你 修改 新 闻 ^ 
新 闻 标 题 : 
更 新 时 间 : 
新 闻 分 类 : 加 作者 ”= | 
^| 
E 
| 
新 闻 内 容 : 
- 
Y 
€ E 
<body> AJOA moos v| 66T x 428v 2 K / 1 $9 Unicode (UTF-8) 
图 5-96 修改 狐 闻 页 面 设计 
NN r1 IE P4 
评 细 操作 步 又 如 下 。 


(1) 打开 news upd.php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 外 按钮 ， 在 弹出 的 菜单 中 ， 选 
择 “ 记 录 集 (查询 )” 选 项 ， 在 打开 的 “记录 和 集 ” 对 话 杠 中， 输入 如 图 5-97 所 示 内 容 。 
(2) 用 同样 方法 再 绑 定 一 个 记录 集 Recordset2， 在 “记录 集 ” 的 设置 如 图 5-98 所 示 。 
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图 5-97 设置 “记录 和 集 Recordset1” 对 话 框 


Zin: Recordset2 | 
表格 : | 和 
a9 全 部 O wem: 


图 5-98 设置 “记录 集 Recordset2” 对 话 框 


(3) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 news_upd.php 网 页 中 的 适当 位 置 ， 如 图 5-99 
所 示 。 其 中 加 入 一 个 隐藏 字段 绑 定 news. id. 


(40 在 “更 新 时 间 ” 一 栏 中 必须 取得 系统 的 最 新 时 间 ， 方 法 和 上 和 面 加 隐藏 子 段 取得 时 间 
的 方法 一 样 ， 和 直接 在 初始 值 了 字段 输入 取得 系统 时 间 的 代码 ， 如 图 5-100 所 示 。 


«input name-"news date" type="text" id="news_date" value=" <?php 
date default timezone set('Asia/Shanghai); 

echo date(" Y-m-d"); 

7» 


(50 单 击 “ 新 闻 分 类 ”的 列表 沫 单 ， 在 “新 闻 分 类 ”的 列表 沫 单 属 性 面板 中 ， 单 击 
区 ”和 蕉 .| 按钮 ， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 ， 设 置 如 图 5-101 所 示 内 容 。 
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5-99 插入 相应 字段 全 news upd.php 网 页 中 


属性 
立 本 域 字符 宽度 D 类 型 回 单行 @) Osa Osme — GOx 
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5-100 加 入 代码 取得 最 新 时 间 
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图 5-101 绑 定 "动态 列表 / 沫 单 ” 


(6) 守成 表单 的 布置 后 ， 要 在 news upd.php 这 个 页 面 加 入 “服务 需 行 为 ”中 “更 新 记 
录 ” 的 设 定 ， 在 news upd.php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ” 面 
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扳 上 的 国 校 钮 ， 在 弹出 的 业 音 中， 选择 “更 新 记录 ”命令 ， 如 图 5-102 所 示 。 
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图 5-102 加 入 “更 新 记录 ”命令 


(7) 在 打开 的 “更 新 记录 ”对 话 框 中 ,设置 如 图 5-103 所 示 内 容 。 其 中 news id 设置 为 
主键 。 


"BRA x 
co ORM. n ws content ARHMBTEM ' TE 
'news date' b FORM. news gor HUATA 日 其 | 
'news author A ' FORM. news author' XE&HNMBÍE 304 


1B: FORM. news id 
jeu. | 整数 y a 主键 


在 更 新 后 ， 转 到 : admin. php E 


5-103 ”设置 “更 新 记录 ”对 话 框 
单 击 “ 确 定 ” 按 钮 ， 即 完成 修改 新 闻 页 面 的 设计 。 


sso 删除 新 闻 页 面 | 


删除 新 闻 页 面 news_del.php 和 修改 新 闻 页 面 差 不 多 ， 如 图 5-104 所 示 。 


示 。 其 方法 是 将 表单 
中 的 数据 从 站 点 的 数据 表 中 删除 。 
详细 操作 步骤 如 下 。 


(1) 打开 news_del.php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 外 按钮 ， 接 独 在 弹出 的 这 单 中 ， 选 
择 “ 记 录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 输 入 如 图 5-105 所 示 内 容 。 


PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


T C: NApache*htdocsknews*Sadmininews del.php | 


管理 员 ， 你 好 ， 你 要 删除 此 新 闻 吗 ? 
新 闻 标题 : | 
新 闻 分 类 : 人 者 [| 


es. 
eh. 


5-105 “记录 集 Recordset1” 对 话 框 


(2) 用 同样 方法 再 绑 定 一 个 记录 集 ， 输 入 设 定 值 ， 如 图 5-106 所 示 。 


Z: 


5-106 “记录 集 Recordset2” 对 话 框 


pO ELELEE 


KEFEN news_id， 如 图 5-107 Pr. 


S C: ÀpacheNhtdocsinewsNadmininews del. php Dx n 
ERED nens php D 


管理 员 ， 你 好 ， 你 要 删除 此 新 闻 吗 ?3 


新 闻 标题 : [Recordseti.news title] E 
新 闻 分 类 : 作者 | [Recordsetl| 


{Recordset1. news_content} ^ 


新 闻 内 容 : 


v 
MC 93- 462 v | E 
561- v 


D <form. .. > <table> Ctr? <td> CLabel? input...) DIU q 100$ 4/667 x 323v 6 K / 1 $^ Unicode (UTF-8) 


图 5-107 字段 的 插入 


(4) 绑 定 记录 集 后 ， 单 击 “ 痢 闻 分 类” 的 沫 单 ， 在 “新 闻 分 闫 ”的 沫 单 属 性 面板 中 ， 单 
击 区 _ 比 按钮 ， 在 打开 的 “动态 列表 / 亲 单 ”对 话 框 中 设置 如 图 5-108 所 示 内 容 。 


per] pn 


|: |"select" dE RE “formi” vi 
+| | 一 PL 


来 自 记 录 集 的 选项 : 


图 5-108” 绑 定 “ 动 态 列表 /菜单 ” 


(5) 完成 表单 的 布置 后 ， 要 在 news_del.php 这 个 页 面 加 入 “服务 器 行为 ”面板 中 “删除 
记录 ”的 设置 。 单 击 “ 应 用 程序 ”向 板 群 组 中 的 “服务 右 行 为 ”面板 上 的 加 按钮 ， 在 弹出 的 
沫 单 中 ， 选 择 “ 删 除 记 录 ” 命 令 ， 在 打开 的 “删除 记录 ”对 话 框 中 ， 输 入 设 定 值 ， 如 网 5-109 
PES 

单 击 “ 确 定 ” 按 钮 ， 完 成 删除 新 闻 页 面 的 设计 。 


PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


首先 检查 是 否 已 定 尺 变 且 : {| 
连接 : v 
表格 : v 
主键 列 : i v 数值 
主键 值 : v news id 
册 除 后 ， 转 到 : 


3r gr P] 47 2$ UL IRI type. add.php 的 功能 是 将 页 和 面 的 表单 数据 新 增 到 newstype 数据 表 中 ， 
页 面 设计 如 图 5-110 所 示 。 


T C: ÀpacheMhtdocsinews*SadninVtrpe add, php -0X 


请 添加 新 闻 分 类 ， 
新 闻 分 类 名 称 : | | 


body? [C£ormi£orm17] m g 100% — «544 x 1B2« 1 K / 1 $^ Unicode (UTF-8) — - 
5-10 新 增 新 闻 分 类 页 面 设计 


详细 操作 步骤 如 下 。 
C) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 右 行 为 ”面板 中 四 按钮 ， 在 弹出 的 染 单 中 ， 选 
择 “ 插 入 记录 ”命令 ， 在 打开 的 “插入 记录 ”对 话 杠 中， 输入 设 定 值 ， 如 图 5-111 所 示 。 


s EH: | forml 


1 news 


: Inewstvype 


iB: | FORM. type name 


提交 为 : [文本 
插入 后 ， 转 到 : admin. php 


5-111 设置 “插入 记录 ”对 话 框 


pO EELEE 


(20 选择 表单 执行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ” 面 
板 中 的 外 按钮 ， 在 弹出 的 染 音 中， 选择“ 检 奉 表 单 ” 命 令 。 打 开 “ 检 奏 表单 ”对 话 框 ， 设 置 
“ 什 ” 为 “必需 的 ” “可 接受 ”为 “任何 东西 "” 如 图 5-112 R. 


可 接受 © 任何 东西 O An 
O 电子 邮件 地 址 O mM | | 到 | | 


图 5-112 设置 “检查 表单 ”对 话 框 


(3) 单 击 “确定 ”按钮 ， 完 成 type_add.php 页 面 设 计 。 


5.47 修改 新 闻 分 类 


修改 狐 闻 分 类 页 面 type_upd.php 的 功能 十 将 数据 表 的 数据 送 到 页 面 的 表单 中 进行 修改 ， 
修改 数据 后 再 更 新 全 数据 表 中 。 页 面 设计 如 图 5-113 所 示 。 


im 
iow] 


C: SApache*ht docshnewssadmin*ltrpe upd. php -0X 


请 修改 新 闻 分 类 
分 类 2 黎 :| | 


图 5-113 ”修改 新 闻 分 类 页 面 设计 


详细 操作 步骤 如 下 。 

(1) 打开 type upd.php 页 面 ， 并 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 的 | 册 j 按 
钮 。 接 着 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 )” 命 令 ， 打开“ 记录 集 ” 对 话 框 ， 在 打开 
的 “记录 集 ” 对 话 杠 中， 输入 设 定 值 ， 如 图 5-114 所 示 内 容 。 

(2) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 type upd.php 网 页 中 的 适当 位 置 ， 如 图 5-115 
所 示 。 其 中 绑 定 一 个 隐藏 字段 为 type_id。 

(3) 完成 表单 的 布置 后 ， 要 在 type upd.php 这 个 页 面 加 入 “服务 器 行为 ”中 “更 新 记 
ox" HIKE, TE type upd.php 的 页 面 上 ， 单 击 “ 应 用 程序 ”和 面板 群 组 中 的 “服务 器 行为 ”和 面 
板 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 更 新 记录 ”命令 。 在 打开 的 “更 新 记录 ”对 话 框 中 ， 


PHP 


输入 设 定 值 ， 如 图 5-116 Wr. 


名 称 ; 
表格 
列 : 名 全 部 O wm. 


5-114 ”设置 “记录 集 ” 对 话 框 


| C: VApachekhtdocsinewsiadminltrpe upd. php* ze 


请 修改 新 闻 分 类 ， 

分 类 名 称 : | fRecordsetl.type name] |Æ | 

: 
SUE 


tr? Cd? input. . . 7] $9 Q, 100€ — »|4T4 x 130v 4 K / 1 fb Unicode QUT] ,: 


5-115 ”字段 插入 全 type upd.php 


formi 


: [news 


newstype 


ÍB: FORM. type id v 
提交 为 : | 整数 MIZE:: 
在 更 新 后 ， 转 到 : admin. php | 


5-116 设置 “更 新 记录 ”对 话 框 
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pO EELEE 


Hub ME” T AREATA t e 
删除 新 闻 分 类 


删除 新 闻 分 类 页 面 type del.php 功能 是 将 表单 中 的 数据 从 站 点 的 数据 表 newstype 中 删 
除 。 详 细 操 作 步 又 如 下 。 

(1) 打开 type del.php 页 面 ， 该 页 面 和 更 新 的 页 面 是 一 样 的 。 单 击 “ 应 用 程序 ”面板 群 
组 中 “ 绑 定 ”面板 的 [二 按钮。 接着 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 〈 查 询 )” 命 令 ， 打 开 
“记录 集 ” 对 话 框 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 输 入 设 定 值 如 图 5-117 所 示 。 


gn: Recordset | 

连接 : |news MG 
表格 :newstype O vj 

3:09 2m  O wem. 


^" n . 
"pe [ 


K| 5-117 设置 “记录 集 ” 对 话 框 


2) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬入 至 type del.php 网 页 中 的 适当 位 置 ， 如 
图 5-118 所 示 。 其 中 绑 定 一 个 隐藏 学 段 为 type_id。 


l C: Apache htdocs news hadmin' trpe del.php - 口 闪 


ul == 
€ 


to <td> naut... Dp [Ra Q 100€ — «[4T4 x 130v 4 K / 1 ÈP Unicode (UTI 
K|5-118 学 段 插 入 全 type del.php 
(3) 完成 表单 的 布置 后 ， 要 在 type_del.php 这 个 页 面 加 入 “服务 占 行 为 ”中 “删除 记 
K” WE. Æ type_del.php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ” 面 


板 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 删 除 记 录 ” 选 项 。 在 打开 的 “删除 记录 ”对 话 框 中 ， 
输入 设 定 值 ， 如 图 5-119 Wr. 


PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


首先 检查 是 否 已 定 久 变量 : 


D|type id {i 数值 
:|URL 参数 


册 除 后 ， 转 到 : admin. php 


图 5-119 设置 “删除 记录 ”对 话 框 


全 此 一 个 功能 完善 、 实 用 的 网 站 痢 闻 发 布 系统 唤 开 发 完毕 ， 谈 者 可 以 将 本 章 开 发 新 闻 发 
布 系统 的 方法 应 用 到 实际 的 大 型 网 站 建设 中 。 


^v^ 


SIJE 留言 板 管理 系统 建设 


留言 板 管理 系统 可 以 实现 网 站 与 访问 者 之 间 的 沟通 ， 收 集 用 户 意见 和 信息 ， 也 是 网 站 
建设 中 必 不 可 少 的 一 个 重要 系统 。 利 用 留言 板 ， 可 以 为 访问 人 员 提 供 友 言 的 机 会 ， 及 时 、 
准确 地 发 表 目 己 的 观点 。 这 些 观 点 被 保留 在 服务 器 上 的 数据 库 中 ， 而 且 可 以 被 任何 一 个 访 
问 站 点 的 人 所 看 到 。 本 章 将 利用 Dreamweaver 的 “插入 记录 ”和 “查询 ”记录 集 命令 ， 轻 
松 实 现 PHP 留言 系统 的 留言 和 奉 询 留言 的 动态 管理 功能 ， 同 时 开始 初步 掌握 通过 手写 代码 
来 实现 部 分 简单 的 功能 。 


sa MA ATJE) EIU 


要 掌握 以 下 知识 点 : 


留言 板 管 理 系 统 的 结构 搭建 

创建 数据 库 和 数据 库 表 

建立 数据 库 连 接 

掌握 留言 板 营 理 系统 中 创建 各 种 页 面 及 页 面 之 间 传 圳 信息 的 技巧 和 方法 
留言 板 管理 系统 常用 功能 的 设计 与 实现 


QL-*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 
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| 系统 整体 设计 规划 


留言 板 管理 系统 在 功能 上 主要 表现 为 如 何 显示 留言 ， 如 何 对 留言 进行 回复 、 修 改 
和 删除 ， 一 个 完整 的 留言 板 管 理 系统 分 为 访问 者 留言 模块 和 管理 者 登录 模块 两 部 分 。 
本 半 要 制作 的 留言 板 管理 系统 的 网 页 及 网 页 结构 ， 如 图 6-1 所 示 。 


留言 板 管理 系统 


index.php 
访问 者 留言 管理 者 登录 
book.php admin_login.php admin.php 
delbook.php reply.php 


图 6-1 系统 结构 图 
留言 板 管理 系 统 共有 6 个 页 面 ， 各 页 面 的 功能 与 对 应 的 文件 名 称 如 表 6-1 所 示 。 


表 6-1 留言 板 管理 系统 网 页 表 


页 面 名 称 E 能 
index.php 留言 内 容 显示 页 面 ， 显 示 留 言 内 容 和 管理 者 回复 内 容 
book.php 留言 页 面 ， 提 供用 户 发 表 留 言 的 页 面 


admin login.php | 管理 者 登录 入 口 页 面 ， 是 管理 者 登录 留言 板 管理 系统 的 入 口 页 面 


admin.php 后 侣 管理 主页 面 ， 是 管理 者 对 留言 的 内 容 进 行 管理 的 页 面 
reply.php 回复 留言 页 面 ， 管 理 者 对 留言 内 容 进行 回复 的 页 面 
delbook.php 删除 留言 页 面 ， 管 理 者 对 一 些 非法 或 不 文明 留言 进行 删除 的 页 面 


页 面 设计 规划 E 


完成 留言 板 宣 理 系 统 的 整体 规划 后 ， 可 以 在 本 地 站 点 上 建立 站 点 文 件 夹 gbook， 将 要 制 
作 的 留言 板 系 统 文件 夹 及 文件 如 图 6-2 所 示 。 


ooo ss 


OQ OO BÓ e o aj 


C:XÁpachexXhtdocsXgbook 


【留言 板 管理 系统 建设 


EIE 


AEG) MEE ERE KEA) IAT 帮助 0) 
四 AR - © LESE E XR | 国 - 
地 址 0) S C: ApacheWhtdocsVgbook 


文件 和 文件 夹 任务 

Q9 ANNER 

PATAREI 
e 

kg HEHH 


dE php 
xn 


RD 4 0 


| PHP m hp 
EAE E AX 


index.php 


«D Tu 


10 个 对 象 24.1 KB 


站 点 规划 文件 


NE 


网 页 美工 方面 ， 主 要 设计 了 首页 和 次 级 页 面 ， 采 用 的 是 标准 的 堪 右 布局 结构 。 
设计 效果 如 图 6-3 所 示 ， 主 要 是 基于 一 个 BtoC 电子 商务 平台 的 留言 系统 的 开发 。 


ETT rn x Nicrozaft 
xeu] aba) EO) Rw IAm Won 

OE- O indo Pam TRAO c. 03 
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留言 页 面 


ntermat Explore 


mE NES | 
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EIL 
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EMER: TIRER AT : 


FARE: i-e 
HR: 010-1245878 


EEA! EE ERRIN 


Coppa ll eeuu com Ine AT nges peered MARIE EESN 


图 6-3 留言 页 面 的 设计 效果 


62 数据 库 设 计 与 连接 


制作 留言 板 管 理 系统 ， 首 先 要 设计 一 个 可 存储 访问 者 留言 内 容 、 管 理 员 对 留言 信息 的 回 
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复 以 及 管理 员 账 号 、 密 码 的 数据 库 文 件 ， 以 方便 管理 和 使 用 。 


本 数据 库 主 要 包括 “留言 信息 意见 表 ” 和 “管理 信息 表 ” 两 个 数据 表 ,“ 留 言 信息 意 
表 ” 命 名 为 gbook,“ 管 理 信 息 表 ”命名 为 admin. 

制作 的 步骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL", 进入 MySQL 数据 库 的 管理 面 
板 ， 如 图 6-4 所 示 。 

(2) 单 击 工具 栏 的 Create CHI) 按钮 并 在 打开 的 下 拉 沫 单 中 单 击 选择 “Database CX 
据 库 )” 人 命令， 如 图 6-5 Bp. 


WIE 
p Procedure 
m Function 
yg scheduled Event 
yg UDF 
mue MAI, Report 


Favorite iuery 


Database 


6-4 打开 MySQL 数据 库 管理 界面 6-5 单 击 选 择 “Database” 命 令 


(3) 打开 “Create Database Wizard (建立 数据 库 问 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
“gbook”。 然 后 再 单 击 Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 ， 如 图 6-6 所 示 。 


Create Database Wizard 
Create Database 
Specify the name for a new database 
Welcome to the Create Database Wizard! 
This wizard allows you to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SQL statement for creating the database and execute it 
on MySQL server. 


Database name gbook 


Register after creating 


Cancel 


6-6 输入 数据 库 的 名 称 gbook 


管理 系统 建设 


(4) 设置 MySQL 数据 库 的 属性 设置 如 表 6-2 所 示 ， 连 接 设 置 如 图 6-7 所 示 。 然 后 再 单 
ik Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 


表 6-2 ”数据库 属性 设置 S 


Host name localhost Port 3306 
User name root 
Password admin 


Create Database Fizard 
Create Database 


Set connection properies for a new database 


Host name localhost v | Port 3306 ^ 


User name 


Password 


a Use server settings 


Collation 


[ ]use tunneling 


Tunneling 
SSH tunneling HTTP tunneling 


[ze ] en ] Coen] 
6-7 ”连接 设置 


(5) 打开 新 建 数据 库 的 SQL 语句 提示 ， 创 建 数据 库 gbook， 直 接 单 击 Next (下 一 步 ) 
按钮 ， 如 图 6-8 Wr. 


Create Database Wizard 
Create Database 
Result SQL statement. Click the Finish button to create a new database. 


Result SAL statement:: 
CREATE DATABASE `gbook`; 


tA 


Click "Finish" to create the database. 


Cancel 
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(6) 单 击 Finish《〈 完 成 ) 按钮 ， 打 开 注册 数据 库 的 设置 画面 ， 选 择 utf8 子 符 集 、 人 简体 中 
文 版 的 GB2312 hk, HAERERE, AU 6-9 所 示 。 


PHP 


Database Registration Info 


Wi Connection | 
Eil Options 
Display Options Host name 
[© Directories 


fV Logs 


User name 


B SSH Tunneling Password 


1i HTTP Tunneling Database name 
Data Options 


Database alias |ghook on localhost 


Client charset (utta 


Font charset 312_CHARSET (Simplified Chinese characters) fs 


ET 
图 6-9 ”选择 简体 中 文 
CI) Hik “OK” GAVO 按钮 ， 就 完成 了 数据 库 gbook 的 狐 增 工作 。 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 分 别 是 
gbook、admin。 建 立 数据 库 后 ， 接 着 再 按 左 边 的 “Connect to Database. 〈 和 连接 数据 库 )” 图 标 


总 将 其 连接 上 。 这 两 张 数 据 表 的 字段 结构 内 容 说 明 如 下 。 


CG) 建立 数据 库 gbook 后 ， 用 上 鼠标 右键 单 击 选择 “Table CRH)” WM, 


中 ， 单 击 选 择 “New Table OIR)” MA, WK 6-10 Pr. 


nagar EE Fs chook on localhost [elrowkl] 
= OG B. 
J Gening Started 

5 Cristi rur rabat 加 Crus Pur Lalo 


Ed Manage existing database lH Create rew database objec 


gf Execute query 


中 Manage permissions 


|) SQL Manager 2007 help system 
E i) MySQL reference 
| :| Internet Resources 


IITEITUITINMEN e) oo rager 2007 home pape n 


LH SEX Manager ZO? on-line documentation e SOL Manager UD FAJ 
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在 打开 的 玉音 


(2) 数据 库 右 方面 面 会 出 现 狐 建 数据 表 (Table) 的 设置 区 域 , 含有 “Table (表格 )”、 
“Fields CJ E20", “DDL (驱动 )”3 个 选项 卡 ， 先 在 “Table (表格 )” 中 输入 数据 表 名 


gbook， 如 图 6-11 所 示 。 


B & a 


L ] LJ 


zs New Table — [gbook on localhost] 


| 8 gbook on localhost [gbook v| 


com DWNG) 


4f Compile 
' Q9) Show SQL help 
[P] Restore default size 


Table |Fields | DDL | 


SME RE 


Table Properties 


Table name 


Storage Options 
Storage engine 


Row format 


^|  Min.rows 


^|. Max. rows 


; Auto increment value 


^| Average row length 


<>< >< >| < < > 


^| Size for index key blocks 
[C] Delay key write 
[C] Temporary 


^|. [C] Check sum 
[C] Pack keys 


Character Sets | File Options | Merge Table Options | Federated Table Options | 


Character set Default v 


Collation Default v 


6-11 输入 数据 表 名 gbook 


G) 然后 再 切换 到 “Fields 内容 )” 选 项 卡 中 ， 输 入 数据 域名 以 及 设 症 数据 域 位 的 相关 
数据 ， 如 图 6-12 所 示 。 对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 计 gbook 的 字段 结构 如 
X 6-3 ZR. 


mR Table Igbo ik ] Ighn nk on ncn un: 
- ^ FedTye Sue Pres. Nu Ma Delad 
L Le id | INILGER 11 


Lr 


i] Refresh 
g Compie 
| Qr Grants on todie 
ces Prin 

taj Show SUL help 
(d; Table Editor options 


VARCHAR 50 
VARCHAR — 20 


(gi Restore detinut stre 


图 6-12 设置 数据 库 


表 6-3 留言 信息 表 gbook 


字段 大 小 Dd EE 


WRARNEE | mpy | TEXT | | 
重点 提示 : 在 此 例 中 ， 管 理 者 可 以 通过 passid 字段 对 留言 审核 是 否 通过 进行 标注 。 
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(4) 创建 admin 数据 表 ， 用 于 后 台 管 理 者 登录 验证 用 ， 输 入 数据 域名 以 及 设置 数据 域 位 
的 相关 数据 ， 如 表 6-4 及 图 6-13 所 示 。 


表 6-4 EH Sua admin 


是 


密码 password VARCHAR 


£ Table — [admin] — [gbook on localhost] 


Object S| | Properties | Fields Indices | Triggers | Data | Dependencies | DDL 

r 一 一 Field Name Field Type Size Preci... Mot N... Default Comment 
gbook on localhost [gbi w s 

| ag INTEGER |11 |o | Null 


时 admin S E username VARCHAR 50 0 Null 


[a Refresh 
f Compile 
ə Grants on table 


Q9) Show SQL help 
(d Table Editor options 
加 Restore default size 


ES! Add new field 
E Edit selected field 
s4 Drop selected field(s) 


图 6-13 创建 的 admin 数据 表 


数据 库 创建 完毕 ， 对 于 本 系统 而 富有 的 新 拉 术 是 如 何 取得 访问 者 的 他 地 址 。 


\ 定义 gbook 丫 点 ) 


在 Dreamweaver CS 5.5 中 创建 一 个 “留言 板 管 理 系 统 ” 网 站 站 点 gbook， 由 于 这 是 PHP 
数据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 。 主 要 的 参数 设置 如 表 6-5 所 示 。 


表 6-5 站 点 设置 的 基本 参数 


站 点 名 称 gbook 
本 机 根 目 录 C:\Apache\htdocs\gbook 
测试 服务 器 CAApacheMtdocsV 
网 站 测试 地 址 http://localhost/gbook/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All Users\Application DataMySQLWySQL Server 5.5\data\gbook 
管理 账号 / 密码 root / admin 
数据 库 名 称 gbook 


创建 gbook 站 点 的 具体 操作 步骤 如 下 。 
(1) 首先 在 CAMApacheMtdocs 路 径 下 建立 gbook 文件 来， 如 图 6-14 所 示 ， 本 章 所 有 建立 


的 网 页 文件 都 将 放 在 该 文件 夹 下 。 


* Cz XApacheXht docs 
wH AmE 查看 WW) Bwa 工具 (T) RH) 
QAE- 29.05 Ps p xtX [Du 


| 地 址 m0) ES C: ApacheWhtdoes 转 到 
^| 名 称 和 大 小 ”类 型 修改 日 期 


Xr IXUS A c .mmServerScripts Arp 2011-7-6 16:06 
个 文件 来 2011-7-11 10:29 
mij nid 六 文件 天 文件 来 2011-T-T 22:04 
(y 移动 这 个 文件 来 MALES 2011-7-9 8:00 
[D 复制 这 个 文件 来 立 件 来 2011-6-15 9:41 
Q 将 这 个 文件 夹 发 布 到 也 phpwyAanin AH apio us 
o Web Ø shop 文件 来 2011-6-30 15:30 
共享 此 文件 来 Bi test AX 2011-T-6 15:55 
A 以 电子 邮件 形式 发 送 &] index. html 1 KB HINL 文档 2004-11-20 15:16 


该 文件 来 内 的 文件 ind 
K MERTXEK = test. php 1 Kb PHP 文件 2011-7-6 8:35 


选 定 1 个 对 象 


6-14 ”建立 站 点 文件 夹 gbook 


(2) 运行 Dreamweaver CS 5.5, Wx s rnm 
“站 点 ”一 “管理 站 点 ”人 命令， 打开“ 管理 站 点 ”对 
话 框 ， 如 图 6-15 所 示 。 

G) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 
有 已 经 定 义 的 站 点 。 单 击 右边 的 “新 建 ” 按 钮 ， 打 开 
“站 点 设置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ”: gbook。 

“本 地 站 点 文件 来” C:\Apache\htdocs\gbook. 


如 图 6-16 所 示 。 


站 点 设置 对 锡 gbook 


6-15 “管理 站 点 ”对 话 框 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweaver 
站 点 通常 包含 两 个 部 分 ; 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 发 布 到 web 上 的 服务 器 上 的 远程 文件 来 。 


您 可 以 在 此 处 当 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : 
AHi diri: | C'\Apachehhtdocs\gbook% 5 


6-16 ”建立 gbook 站 点 


(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 此 |， 打 开 “ 基 本 ” 


PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


选项 卡 ， 进 行 如 图 6-17 所 示 的 参数 设置 。 
“服务 絮 名 称 ” gbook. 
“连接 方法 ” 本 地 /网 络 。 
“服务 絮 文 件 来” C:\Apache\htdocs\。 
“Web URL”: http:// localhost/gbook/. 


靖 点 设置 对 儿 gbook 


服务 器 名 称 
连接 方法 
服务 器 文件 
web Rs 


6-17 设置 “基本 ”选项 卡 


(5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 。 单 击 “ 维 护 同步 
言 息 ” 复 选 按钮 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 6-18 所 示 。 


站 点 设置 对 锡 gbook 


远程 服务 器 


M 维护 同步 信息 
口 ] 保存 时 自动 将 玄 件 上 传 到 服务 器 
O 自用 文件 职 出 功能 

[V 打开 文件 之 前 取出 


取出 名 称 : O 


电子 邮件 地 址 : 


6-18 设置 “高 级 ”选项 卡 


(6) 单 击 “ 人 保存” 按钮， 返回 “服务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 按钮 ， 
如 图 6-19 所 示 。 


板 官 理 系 统 建设 


一 


rid m$ gbook 


您 将 在 此 位 置 选择 学 载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 


T — Internet 服务 提供 商 (SP) 或 web 管理 员 。 


版 本 控制 


p SARE 注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步 又。 如 果 要 连接 到 Web 并 发 
AU. DEVE SEN. 
dS UA 
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单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 
刚 所 设置 的 站 点 gbook。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 杠 ， 这 样 束 完成 了 
Dreamweaver CS 5.5 测试 留言 板 管理 系统 网 页 的 网 站 环境 设置 。 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 留言 板 管理 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数 


据 库 的 连接 设置 如 下 。 
(1) 将 区 盘 中 设计 的 本 章 文件 复制 到 站 点 文件 夹 中 ， 打 开 index.php, Anl 6-20 所 示 。 


DW | ats -| u—— O sue 所 瑟瑟 二 
xe müm sto a) w BLO ASC) © Sow un 


infer php x 
P me|d:| su [Voi sHAR 5m M O. £N. 


| B ^ sm. SKET 
65 C NE 


B. TUTGOTEHESASSNE: 
E ^| v 1 WHIRO TAS. 
v 2 GEÉ-WIMH. 


3 eRu^cmMEHUEZH. 
4 号 0) pHs 


Ws (554) = 


LIEU EE — ——— — E rA eE cR EYREETERIDZEGUEURT. I Lui 


(593 "Ü mors «gs senat: : 
— -L. pa 


ius " EMEND: DS SETS: i —————À— PCR i 
HEN : RR T eo v XH"E v 
| 153 ? i &o|507358/|7 


NSAZREAS: 
————: AE SO MA -de C 
* o Conzectiens 


v 
EIQ 100* ~ 0 x 468v 126 E / 3 9 Woiesde ATEO) 


Seir (ilo Cu? «4 (alo QR D 
| ONXO Xx x Rx Y 有 7 bszsuswmo «X 
ma x "DL "Qo BRO 
Fomu — viXo  ;/TAGW[) seor | 
cx $RONU v mo X wol! 


图 6-20 ”打开 网 站 首页 
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(2) 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 令 ， 打 开 “ 数 据 库 ”面板 。 在 “数据 
库 ” 面 板 中 ， 单 击 选 择 “+” 图 标 ， 并 在 打开 的 菜单 中 选择 “MYySQL 连接 ”命令 ， 如 图 6-21 
所 示 。 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


L JATE 站 点 。 
2. WEE TENUES, 
«^ 3. 设置 站 点 的 Mi 
4.” 单 击 上 面 的 + IER REERE. 


图 6-21 选择 MySQL 连接 


(3) Æ “MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 gbook, “MySQL 服务 器 ”名 
Jj localhost, “用户 名 ”为 root, 1A admin， 如 图 6-22a 所 示 。 选 择 所 要 建 并 连接 的 数据 
库 名 称 ， 可 以 单 击 “ 选 取 ” 按 钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 
数据 库 gbook， 具 体 的 设置 内 容 如 图 6-22b 所 示 。 


ESEN: 
iysqr REE 
ss. 

d 


performance schemaold 


b) 
图 6-22 WE MySQL 连接 参数 


(4) fau; "uA Ju, MAS MySQL 数据库 的 连接 是 否 正 确 ， 如 果 正 确 则 会 出 现 一 
个 消息 框 ， 如 图 6-23 所 示 ， 这 表示 数据 库 连 接 设 置 成 功 。 


5 理 系 统 建 设 


NySQL 连接 


Dreamweaver 


和 连接 名 称 : 


"SQL 服务 器 : | | i ) 成功 创建 连接 脚本 。 
HP] o 
xr. 确定 


AEE: |E 
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单 击 “ 人 确定 ”按钮 ， 返 回 编 辑 页 面 ， 在 “数据 库 ” 和 面板 中 则 显示 绑 定 过 来 的 数据 库 ， 如 
图 6-24 所 示 。 


Hugm|epe, 服务 器 行为 | = 


+t 一 GUESS: PH C 


E T Ebook 
SE MEg 
E- ERI admin 


E1- 视图 
E-e TAE 


6224 ” 绑 定 的 数据 库 


留言 板 管理 系统 页 面 


I 


留言 板 管理 系统 分 前 台 和 后 从 两 部 分 ， 这 里 首先 制作 前 合 部 分 的 动态 网 页 。 
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在 首页 index.php 中 ， 单 击 “ 留 言 ” 链 接 时 ， 打 开 留 言 页 面 book.php， 访 问 者 可 以 在 上 
面目 由 发 表意 见 ， 但 管理 员 可 以 对 非法 或 不 文明 留言 进行 删除 、 修 改 等 。 

其 详细 制作 的 步 又 如 下 。 

C1) HARPA KIM index.php, WEE “现在 时 间 是 :” 后 面 加 一 个 PHP 代码 : 


<?php 
date_default_timezone_set('Asia/Shanghai'); 
echo date("Y-m-d h:1:s"); 

7> 


得 到 系统 的 当前 时 间 ， 在 文字 “留言 ”上 做 一 个 超 链接 ， 链 接 到 book.php, XR Ul 
图 6-25 所 示 。 


"P PHP+ 


ec: SÀpache'htdocsgbook^indez. phi 


| PPan 


ALS i Sedes M NES 


EST EXIT e | IORSRIFAHESEGRDE D 请 单 击 背 言 结 我 们 留言 ， D Xinss-MiaMemeN. 
is in —3 


E guns DEAF: 


: ESTEE: 


lady» tabe dy 45 able SaD td? tablet Ctr? ted [Ry 100$ Tr x Me 125 E / 3 È Unicode (UTF-8) 
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(2) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 “ 比 定 ” 面 板 上 的 按 
钮 外， 在 弹出 的 菜单 中 选择 “记录 集 (查询 )” 命 令 ， 在 该 对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 “记录 集 ” 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 选择 连接 对 象 为 gbook。 

3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 gbook。 

4) 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

完成 后 的 设置 如 图 6-26 所 示 。 


» 9 全 部 O sem. 
In 
subject 


content 
reply 
date 


mt E 0 00 ve 
DE Lo 
排序 无 上 


6-26 设置 “记录 集 ” 对 话 框 


(3) 单 击 “ 局 级 ”按钮 ， 进 行 蜗 级 模式 绑 定 ， 在 SQL 文本 框 中 输入 如 下 代码 : 
SELECT * 


FROM gbook /从 数据 库 中 选择 gbook 表 
WHERE passid-0 /选择 的 条 件 为 passid X 0 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


板 管理 系统 建设 


当 此 SQL 语句 从 数据 表 gbook 中 查询 出 所 有 的 passid 字段 值 为 0 的 记录 时 ， 表 示 此 留 
言 已 经 通过 管理 员 的 审核 ， 如 图 6-27 所 示 。 


: gbook 


: SELECT * 
FROM ebook 
WHERE passid=0 


d. Hund 


6-27 输入 SQL 语句 


(4) 单 击 “ 确 定 ” 按 钮 ， 完 成 记录 集 的 绑 定 ， 然 后 将 此 字段 插入 全 index.php 网 页 的 适 
当 位 置 ， 如 图 6-28 所 示 。 


= C: Nl pacha'ht doesigbook' inder. phpt =- OX 


| dock phe 


d sem cHEES :| 
Ls Dm gk : 
col BEITHAREE DE, ARENE. A 我 们 会 第 一 时 间 给 你 答复 。 : 
TT 
、  SRBIRsIPRONEX RENS: 
: [Rsconteni] ， 


3 ers E LETETT ASA RR 
: ERRE Fa sia EIPS: 


WS AA Gr 4b Calle "— Cform£orml1? [k]£) om  . TH x 416v 1298 E / 3 £9 Unicode QITF-8) . 
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(5) 在 “管理 回复 ”单元 格 中 ， 根 据 数 据 表 中 的 回复 字段 reply 是 人 否 为 衬 ， 来 判断 管理 员 是 
否 访 问 过 。 如 果 该 字段 为 宝 ， 则 显示 “对 不 起 ， 暂 无 回复 !” 字 样 信息 ， 如 采访 字段 不 为 衬 ， 耽 
表明 管理 员 对 此 留言 进行 了 回复 ， 同 时 还 会 显示 回复 的 时 间 和 内 容 。 

(6) 在 设计 视图 上 ， 选 中 “管理 回复 ”单元 格 ， 找 到 “对 不 起 ， 暂 无 回复 !” 字 样 ， 并 
加 入 代码 ， 如 图 6-29 所 示 。 
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€ C: \Apache\ht docsVgtook Ni ndez. php .Dx 


ERIP chock php Y 
O xin. o 


<td bgcolor=" 8F3F3F3" WSs 
«td height="30" bgcolor "Fors € 
€td»«table vidths"1005" borders"O0" cellspacings"0" cellpsddings"0"» 


colspane"3" bg ore"AF3F3F2"»&nbsp:* 


Cable) C? CD Corn. |. 5 Gable? Cu? 4D Cable? Gu] 129 K / 3 F^ Vaicede MPO) — 


图 6-29 ”加 入 代码 


<?php 
if ( $row_Rs['reply']= empty( $row. Rs['reply'])) { 

echo "XJA, HEER! "yR repy FRA TUER 
else( ?> /l'a A A RI S ZR EA PITE 


«br /> 


管理 员 在 <?php echo $row. Rs['redate']; ?> 回复 内 容 : «br /> 


<?php echo $row. Rs['reply']; }?> 


重点 提示 : 通过 df..else 条 件 判 断 语 名 实现 判断 的 功能 。 


CI) 由 于 index.php 负面 显示 的 是 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 则 只 会 显示 数据 
库 的 第 一 笔 数据 ， 因 此 需要 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 设 定 ， 选 择 index.php 页 
面 中 记录 的 那 一 个 表格 ， 如 图 6-30 所 示 。 


Cc:\Apache\htidors\ebook\inder php .Dx 
€ hA chook php Y 
ee n T ——((——^(—————————————— 
你 的 位 置 … 在 贱 久 言 — 现在 时 间 是 : m ^| 
TONS pr e ses 
AALE | Jo ERI LEER GUNDR , MATE NAXOS. X029 3652. 
PIED SOR page : OE Ai KA 
3 ERR RETH : TET HERETTETTTT 
i f * B(RsIP)DN E 留言 内 容 : 
s: 3 {Rs content] 
E 
SAER mie ENAS : 
.. Rs reply) ; z 
| 治 淡 合作 
X Pi: 010412345676 
传真 010-12345678 
E usel- tes [s “| 


D» Ctable? Qr? Q4 fora SE Ctable» Ctr) <td> Ctable? Ctr? €t» LI ey uq 100$ - v TTi x 416» 129 E / 3# Whicode (UTT-8) 


图 6-30 选择 要 重复 显示 的 内 容 


理 系 统 建设 


(80 单 击 “应 用 程序 ”面板 群 组 中 “服务 喜 行 为 ”面板 中 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
“重复 区 域 ” 命 令 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 定 显 示 的 数据 选项 ， 如 疼 6-31 rn. 


图 6-31 设置 “重复 区 域 ” 对 话 杠 


(9) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

(10) 鼠标 移 至 要 加 入 “记录 集 导 航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “数据 ”类 别 中 ， 单 
击 | 到 工具 按钮 ， 在 弹出 的 对 话 框 中 选取 要 导航 的 记录 集 以 及 导航 的 显示 方式 ， 如 图 6-32a 所 
示 ， 然 后 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 此 时 页 面 孢 会 出 现 该 记录 集 的 导航 条 ， 效 果 如 
| 6-32b 所 示 。 


记录 集 导 航 条 


[^T vl 
1 Ea 7*1 现在 时 间 是 : T] za] 


ED enmener 
iij SES: RB IPIS LI sU e E 
RARE Duc a ere Edd aa 
测 
SPEI : BORER edate ] BRE P 
iini Es SELON TOME 
l FPH: oine 
E R: mrz ; : 
| RxADE&RO— ERRIN: “| 
[Sor Cable? (tr? Ta Cable? tr a cables  [k]£g om v| x 46 13A K / 3 Wie (UTF-8) 
b) 


图 6-32 加 入 “记录 集 导 航 条 ” 
(11) 将 鼠标 移 至 页 面 表格 的 右上 角 ， 并 在 “插入 ” 列 的 “数据 ”类 别 中 ， 单 击 | 加 工具 
按钮 ， 在 弹出 的 对 话 框 中 ， 选 取 要 显示 状态 的 记录 集 ， 如 图 6-33a PR, PA ME” T 
钮 ， 回 到 编辑 页 面 ， 此 时 页 面 束 会 出 现 该 记录 和 集 的 导航 状态 ， 如 图 6-33b Pr. 


PHP 


0 50 o o e 


QL*Dreamweaver ELLITITCNBELI. 


Recordset Navigation Status 


Recordset: HC 


[ors 


iu 记录 1 到 5 (总 共 10 个 记录 


T Ci Mpachatht does Vrbook V inder. php 


POF RTR: T P NONE TEE 
来 目 (Rs JP} 的 朋友 在 GERE: 


NE ETRE (Rendi) ERAS: : 
escis ES TITTEN "——S : 


MARRE RERUMS 


t EPRE: raem 
ER: 010-12345678 


t TEX ck Erm : "—- — 
hody Cable? Ctr? Ct Cable? Ctr? Cub t| Q 100€ 
b) 


图 6-33 加 入 “记录 集 导航 状态 ” 


-de I K/3 5 Wicd MTA — 


人 至此， 留言 板 的 首页 index.php 设计 完成 。 打 开 IE 浏览 器 ， 在 地 址 栏 中 输入 


http://127.0.0.1/ index.php， 对 首页 进行 测试 ， 由 于 现在 数据 库 中 没有 数据 ， 所 以 测试 效果 如 
图 6-34 所 示 。 


JEt Nicrozaft Internet Explorer 
Sic) dec) Ev duEG) IAm Shod 
QmE-o- DEGAR *-x e 


SIM NE S 
80 E] hg: //127.0.0. 1 gboo/ 


EET 


BN | sam w MEEF [ fa Ti) | (fae. I 


PARR- MEE 
G gts 
C ILL LIS MDILIEILIM E NEC.-I all: 
:记录 1 到 0 总 失 D 

ID2 HEEN: 


mH E | ERE 
MENAS :2011-07-1209 2732 


ETEN : 对 十 晤 ， 暂 无 回复 人 


FARA: ti HeT 
情 真 :01012556TE 


TA GS EFRI 


Cogyzigbt(ro01 1-2017 htmbure eom Ine AT rights maerved TET (E EUNN 


6-34 留言 板 管理 系统 主页 测试 效 末 
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本 节 将 要 制作 访问 者 在 线 留言 功能 ， 其 主要 技术 是 通过 “服务 器 行为 ”面板 中 的 “插入 QU 


记录 ”功能 ， 实 现 将 访问 者 填写 的 内 容 插入 到 数据 表 gbook 中 。 

详细 的 制作 步骤 如 下 。 

(1) 执行 末 单 “文件 ”一 “新 建 ” 命 令 ， 打 开 “ 新 建文 档 ” 对 话 框 ,创建 新 页 面 。 执 行 
亲 单 “文件 ”一 “为 存 为 ”命令 ， 将 新 建文 件 在 根 目录 下 你 存 为 book.php。 

(20 供 访问 者 留言 的 静态 页 面 book.php， 与 主页 面 index.php 4355. 2C Ul 6-35 
所 示 。 


四 C:\Apache\htdocs\Ebook\book. php Sal 


F BALARA 


eS 
<body> <table> <tr> <td> 
6-35 ”设计 的 book.php 页 面 效 果 


(3) 在 留言 板 表单 内 部 ， 分 别 执行 3 次 “搬入 记录 ”一 “表单 ”一 “隐藏 区域 ”命令 。 
插入 3 个 隐藏 区域， 选中 其 中 一 个 隐藏 区域， 将 其 命名 为 PP， 并 在 属性 面板 中 对 其 赋值 ， 如 
图 6-36 PZR o 


«input name-"IP" type="hidden" idz"IP" value="<?php echo $_ SERVER[REMOTE ADDR'];?»"/» 
/ 目 动 取得 用 户 的 卫 地 址 


A] Feli. 1e 


IB (V) php echo $ SERVER[ REMOTE ADDE 47 


6-36 ix IP 


(40 再 选择 另外 一 个 隐藏 区 域 命 名 为 date， 并 在 “ 值 ” 文 本 框 中 输入 获取 系统 时 间 的 代 


tun 6-37 所 示 。 


«input name="date" type="hidden" id="date" value=" <?php 


"s PHP«-MySQL-*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


date default timezone set('Asia/Shanghai); 
echo date(" Y -m-d h:i:s"); 
?>">/ 获 取 系 统 即 时 时 间 


EIE 


IN] ci DE eh 
iB(V) |Cphpdate default timezone setl 7 


6-37 设置 date 


(50 同样 设置 第 3 个 隐藏 区 域 的 字段 名 称 为 passid,“ 值 ”为 0， 表 示 任 何 留言 者 在 留言 时 
生成 的 passid 值 为 0， 管理 者 可 以 根据 这 个 值 进行 判 新 ， 方 便 后 面 的 管理 。 如 图 6-38 所 示 。 


RE 
IN ES [x det 
iB) o 7 


6-38 设置 passid 值 为 0 


(60 单 击 “应 用 程序 ”面板 数目 中 的 “服务 堪 行 为 ”面板 中 的 邮 j 按 钮 ， 在 弹出 的 沫 单 
中 选择 “插入 记录 ” 在 打开 的 “插入 记录 ”对 话 框 中 设置 如 下 参数 。 

D 从 “连接 ”下 拉 列 表 框 中 选择 连接 对 象 为 gbook。 

2) 从 “搬入 表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 gbook。 

3) 在 “插入 后 ， 转 到 ”文本 框 中 输入 index.php. 

4) 在 “ 列 ” 列 选项 中 会 自动 配置 相应 的 字段 插入 ， 其 中 没有 配置 的 值 是 供 管理 者 进行 
插入 使 用 的 。 

完成 后 的 设置 如 图 6-39 所 示 。 


7 subje "n WP H 3: r. " sd 
f je 欠 ， ont ent E ， EE 
; reply 没有 获 职 值 。 

P^ FORM. date’ 获取 值 作 浇 “日 期 ' 
没有 获取 值 。 


E ES igs um ,于 AS 
i M sid HEYAH E 


xj 


插入 后 ， 转 到 : index. php 


6-39 ”设置 “搬入 记录 ”对 话 框 
N ) A WME” A, PAAR irit, MAh book.php“ 插 入 记录 ”的 


留言 板 管理 系统 建设 _ 


(8) 有 坚 访 问 者 进入 留言 页 面 book.php 后 ， 不 填 任 何 数据 区 直接 把 表单 送出 ， 这 样 数 
据 库 中 就 会 自动 生成 一 笔 空 白 数 据 。 为 了 阻止 这 种 现象 的 发 生 ， 须 加 入 “检查 表单 ”的 行 
为 。 有 具体 操作 是 在 book.php 的 标签 检测 区 中 ， 单 击 <forml> 这 个 标签 ， 然 后 再 单 击 “ 行 为 ” 
面板 的 按钮 节 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 奉 表 单 ” 命 令 。 

49)“ 检 和 奋 表 单 ” 行 为 会 根据 表单 的 内 容 来 设 定 检 得 方式 ， 留 言 者 一 定 要 盾 入 标题 和 拓 
容 ， 因 此 将 subject, content 这 两 个 字段 的 值 义 选 “必需 的 ” 复 选 按钮 ， 这 样 就 可 完成 “检查 
表单 ”的 行为 设 定 了 。 有 具体 设置 如 图 6-40 HR. 


input "username" 
input password" 
: input subject" 


可 接受 : ”任何 东西 O 数字 
O 电子 邮件 地 址 O 数字 从 | | 到 | | 


6-40 WE AAKE” ODE 
单 击 “ 确 定 ” 控 钮 ， 完 成 留言 负面 的 设计 。 


于 是 ”后 台 管 理 功能 的 设计 


言 板 后 台 管 理 系 统 可 以 使 系统 管理 员 通 过 admin_login.php 进行 登录 管理 ， 管 理 员 登 
录 页 面 的 设计 效果 如 图 6-41 所 示 。 


四 C: AApachekht docskgbook*Nadmin login. php -Dx 


<body> <form#forml > R] Q 100% 4/571 x 169v 1 K / 1 f? Unicode (UTF-8). 


6-41 管理 员 登 录 页 而 


管理 页 面 是 不 允许 一 般 网 站 访问 者 进入 的 ， 必 须 受 到 权限 约束 。 
详细 操作 步 又 如 下 。 


f PHP + QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(1) 打开 制作 的 静态 页 面 admin_login.php。 单 击 “ 应 用 程序 ”和 面板 群 组 中 的 “服务 器 行 
为 ” 面板 上 的 按钮 [出 ， 在 弹出 的 菜单 中 ， 选 择 “ 用 户 身 份 验证 /登录 用 户 ” 命 令 ， 弹 出 “ 登 
录用 户 ”对话 框 ， 在 这 里 做 如 下 设置 如 果 不 成 功 ， 将 返回 主页 面 index.php; 如 果 成 功 ， 将 
登录 后 台 管 理 主页 面 admin.php， 如 图 6-42 所 示 。 


从 表单 获取 输入 : | forml 
用 户 名 字段 : username 
密码 字段 : password 


使 用 连接 验证 :| ebook 
表格 : | admin 

用 户 名 列 : username 

密码 列 : password 


如 果 登 录 成 功 ， 转 到 : admin. php pls... 


[] 转 到 前 一 个 URL( 如 果 它 存在 ) 
如 果 登 录 失 败 ， 转 到 : index.php pls... 


基于 以 下 项 限制 访问 : © ”用户 名 和 窗 码 
〇 ”用 户 名 、 密 码 和 访问 级 别 
获取 级 别 自 : ;1 


图 6-42 设置 “登录 用 户 ” 对 话 框 


(2) 执行 菜单 “窗口 ”一 “行为 ”命令 ， 打开“ 行为” 面板， 单 击 “行为 ”面板 中 的 
[出 按钮， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 设 置 
username 和 password 文本 域 的 “ 值 ” 都 为 “必需 的 ”， “可 接受 ”为 “任何 东西 ”如 图 6-43 
所 示 。 

(3) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 管 理 员 登 录入 口 页 面 admin login.php 的 设计 
与 制作 都 已 经 完成 。 


[input "username" (R) 
input "password" (R) 
het : 


mx. © gaza 〇 数字 
O 电子 邮件 地 址 O 数字 从 | | 到 | | 


图 6-43 WB "Rex out 


后 台 管 理 主页 面 


后 台 管 理 主 页 面 admin.php 是 管理 员 由 登录 的 页 面 验证 成 功 后 所 转 到 的 页 面 。 这 个 页 面 


板 管理 系统 建设 


提供 删除 和 编辑 留言 的 功能 ， 效 果 如 图 6-44 所 示 。 


四 C:\Apache\htdocs\Ebook\admin. php -Dnx 


PHP. 


x] xs rH 
H r1 已 2 
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< 
<body> <table> <tr> «a» KoA 


< 


lili 


FN 
A]? Qj 10058 4| T82 x 348» 53 K / 2 fb Unicode (UTF-8) 


图 6-44 “管理 主页 面 ” 的 设计 效果 

详细 操作 步骤 如 下 。 

(1) 打开 admin.php 页 面 ， 此 页 面 设计 比较 简单 ， 在 这 里 不 做 详细 说 明 。 单 击 “ 绑 定 ” 
面板 上 的 | 曲 按 钮 ， 在 弹出 的 对 话 框 中 ， 选 择 “ 记 录 集 (查询 )” 命 令 ， 在 打开 的 “记录 和 集 ” 
对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 gbook。 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

5) 设置 “排序 ”方法 为 以 ID 降序 。 

再 单 击 “确定 ”按钮 后 就 完成 设 定 ， 如 图 6-45 所 示 。 


am: Bs | 
i 
列 : 9 全 部 O wem. 


sm 


图 6-45 设置 “记录 和 集 ” 对 话 框 


(2) 绑 定 记录 集 后 ， 将 记录 集 字 段 插入 至 admin.php 网 页 的 适当 位 置 ， 如 图 6-46 所 示 。 


PHP+ QL-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


T C: XÀpacheXht docskgbook'a dmin. php -0x 


CES book. php 


首页 | 新 闻 动 态 | 信息 服务 言 筷 知识 BEP TS Ip Wm 
| 你 的 位 置 : ESENE | 


:ReID) Rs subject} (Rs content) i "| WE BEC. 
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一 一 <table> <tr> <td> <table> <tr> <td> <table> <tr>Ktd) "AES Q 100€ v182 x 324« 56 K / 2 15 Unicode (VIF-8) - 
图 6-46 插入 字段 全 admin.php 网 页 
(3) admin.php 页 面 的 功能 是 显示 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 则 上 只 会 显示 数据 


库 的 第 一 笔 数 据 ， 需 要 加 入 “服务 器 行为 ”中 的 “重复 区域” 命令 ， 选 择 admin.php 页 面 中 
与 记录 有 天 的 那 一 行 表格 ， 如 图 6-47 所 示 。 


9596 (712) v 


Sb 


it 
图 6-47 选择 要 重复 的 内 容 


(4) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行 
为 ”面板 上 [由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 重 复 区 
域 ” 命 令 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 置 一 页 
显示 的 记录 数 ， 例 如 10 条 记录 ， 如 图 6-48 所 示 。 

(5) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 会 发 现 先 
前 所 选取 要 重复 的 区 域 左上 角 出 现 了 一 个 “重复 ”的 灰 
色 标 签 ， 这 表示 已 经 完成 设置 。 

(6) 首先 选取 记录 集 有 记录 时 ， 要 显示 的 记录 表格 如 网 6-49 所 示 。 


Ei C: \Apache\htdocs\ebook\admin. php -0x 


EAE zbook php 


(Rs 1D) Rs.content) 


图 6-48 设置 “重复 区 域 ”对 话 杠 


E 你 的 位 置 : 管理 主页 面 


2896 (198) v 
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< TT Fm 
Le? <tr> € P [<table ! <tr> <td> [k] Q 1008 v7T82 x 324v 5T K / 2 $5 Unicode (UTF-8) 


图 6-49 选择 有 记录 时 显示 页 面 
CI) 单 击 “ 服 务 需 行 为 ”面板 中 的 外 按钮 ， 在 弹出 的 集 音 中， 选择 “显示 区 域 / 如 果 记 
录 集 不 为 空 则 显示 区 域 ” 命 令 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 中 ， 选 择 
“记录 集 ” 下 拉 列 表 框 中 的 “Rs” 选 项 ， 如 图 6-50a 所 示 ， 再 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 


页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左上 角 ， 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰 
色 卷 标 ， 这 表示 已 经 完成 设 定 ， 如 图 6-50b Br. 


o fE-T 2S zr M aom 


T C:\Apache\htdocs\Ebook\admin. php* 


HIRED abook. php 


T82 x 324v S8 K /2 秒 Unicode (UTF-B) — : 


6-50 ”完成 的 设置 
(8) 输入 记录 集 没 有 记录 时 要 显示 “目前 没有 任何 留言 >， 如 图 6-51 所 示 。 


T C: XApachekht docsNgbook*a dmnin. php* 


Pha book php 


PHP wi 


RsID) :{Rs.subject} E 
m 前 没有 任何 留言 


| 国 "i 
<body> <table> Ctr? <td> <table> <tr> <td> LN T82 x 324» 58 K / 2 fU Unicode (UTF-8B) ~ 


图 6-51 选择 没有 记录 时 显示 页 面 

(9) 单 击 “服务 占 行 为 ”面板 中 的 昌 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 显 示 区 域 / 如 果 记 
录 集 为 空 则 显示 区 域 ”命令 ， 在 打开 的 “如 果 记 录 
集 为 空 则 显示 区 域 ” 对 话 杠 中， 选择 “记录 集 ” 下 DIERAN 
MIRER HI “Rs” WW, HA "sk Ael 
到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 
角 ， 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 
郑 标 ， 这 表示 已 经 完成 设 定 ， 如 网 6-52 Bp. 


图 6-52 设置 “如 果 记 录 集 为 空 则 显示 区 域 ” 
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(100 将 光标 移 至 要 加 入 “记录 集 导 航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “应 用 程序 ”类 别 
中 ， 单 击 国 工具 按钮 ， 在 弹出 的 对 话 框 中 ， 选 取 要 导航 的 记录 集 以 及 导航 的 显示 方式 ， 如 图 
6-53a 所 示 ， 然 后 单 击 “ 确 定 ” 控 钮 回 到 编辑 页 面 ， 会 及 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 
图 6-53b 所 示 。 


显示 方式 : © yE 


O mg 


T C:\Apache\ht docs\Ebook\admin. php* -Bx 


首页 | 新 闻 动 态 | 信息 服务 | 信息 知识 | 信息 产业 | EG | AAR 


| 如 果 符合 此 条 件 则 显示 ... 
目前 没有 任何 留言 


图 6-53 ”加 入 “记录 集 导 航 条 ?” 
(11) 单 击 页 面 中 的 “回复 ”文学 ， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 ， 选 择 用 来 显示 详细 记录 信息 的 页 面 
reply.php， 设 置 如 图 6-54 PZR. 


选择 文件 名 自 : GERI 站 点 根 目录 
〇 数据 源 


站 点 和 服务 器 ... 


查找 范围 加 :| O ebook «odorum 


(C3. mmServerScripts 


(3). notes 


[Connections 


O dated 
(images 


Mcd admin. php 


WA 0: reply. php 


次 件 类 型 (T): | 所 有 文件 (o) Y 


VRL: reply. php 


相对 于 : | * | admin. php 


在 站 点 定义 中 更 改 默 让 的 链接 相对 于 


6-54 ”选择 链接 文件 


(12) 单 击 “ 参 数 ” 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 将 参数 名 称 命 
名 为 DD， 值 设置 如 图 6-55a. b 所 示 。 


Jl 


<?php echo $row Rs[ ID... 


格式 : 无 


HH: <?php echo $row Rs['ID']; ?> 


a) 
图 6-55 “参数 ”和 “动态 数据 ”对 话 框 
(13) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 选 取 编 辑 页 面 中 的 “删除 ”二 字 ， 在 “属性 ” 
面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 选择 
用 来 显示 详细 记录 信息 的 页 面 delbook.php， 并 设置 传递 ID 参数 ， 如 图 6-56a、b 所 示 。 


选择 文件 名 自 : 人 文件 系统 EIE J 


SRE T): | 加 ebook — |. Wdodrtm 


XA:  |delbook. php | 


TSE C): | 所 有 文件 (e v| [ 取消 


| delbook. php?ID-4?php echo $row Rs['ID']; | 


图 6-56 设置 “删除 ”的 链接 
(145 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行 
为 ” 面板 上 的 [出 | 按钮 ， 在 弹出 的 沫 单 中 选择 “用 户 身 份 验证 /限制 对 页 的 访问 ”命令 ， 在 打 
开 的 “限制 对 页 的 访问 ”对 话 框 中 ， 选 择 “ 如 果 访 问 被 拒绝 ， 则 转 到 admin login.php 页 
面 ， 如 图 6-57 Pp. 


基于 以 下 内 容 进 行 限制 : © ”用 户 名 和 密码 
〇 ”用 户 和 名、 密码 和 访问 级 别 


选 职 级 列 : 


如 果 访问 被 拒绝 ， 则 苇 到 : [aanin_ login php 


图 6-57 设置 “限制 对 页 的 访问 ”对 话 框 
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单 击 “确定 ”按钮 ， 就 完成 了 后 人 台 管 理 页 面 admin.php 的 制作 。 


EZE 


回复 留言 的 功能 主要 通过 reply.php 页 面 对 用 户 留 言 进 行 回 复 ， 实 现 的 方法 是 将 数据 库 
的 相应 字段 绑 定 到 页 面 中 ， 管 理 员 在 “回复 内 容 ” 中 盾 写 内 容 ， 单 击 “ 回 复 ” 按 钮 ， 可 以 将 
回复 内 容 更 新 到 gbook 数据 表 中 ， 页 面 效 果 如 图 6-58 所 示 。 


paces UE dese a'bocki reply .Bhp .Dx 


HENA : 


1 
mut. t. 
ax TNN : 
j ILE IUE 
| WssE: 
| wsme: 


1 
|o BEAR: 


cam  — 
1 ü 
ur 下 一 一 站 ee E 
la x | 
[eee [AEA i — . O6 acie 19€ K /3 Mr Maiede QI) — | 


图 6-58 回复 留言 页 面 效 果 
动态 功能 的 制作 步骤 如 下 。 
(1) 创建 replyphp 页 面 ， 并 单 击 “ 绑 定 ” 面 板 上 的 [地 按钮 ， 在 弹出 的 选项 中 ， 选 择 
“记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 进 行 如 下 设置 。 
D 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 
2) 从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连 接 对 象 gbook。 
3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 gbook。 
4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 
5) 设置 “筛选 ”的 方法 为 : ID = URL 参数 ID. 
再 单 击 “ 确 定 ” 按 钮 后 残 完成 设 定 ， 如 图 6-59 Br. 


6-59 设置 “记录 集 ” 对 话 杠 


(20 绑 定 记录 集 后 ， 再 将 记录 集 的 字段 插入 至 reply.php 网 页 的 适当 位 置 ， 如 图 6-60 所 示 。 


me VMipachelhtdocsVgbookVreplr. php 


nx 
T 


EDN 您 要 回复 留言 的 ID 号 是 | {Rs. ID} S 
er CEDE Hee o 
Ped ied LETS lf. IPL 


Re content} 


HT 


: 客户 电话 : 010-12345678 
E GMT 8 40 40cm armomo 


一 一 一 <tr> <td> <table> <tr> <td> CERREN [À | : T86 x 4698» 128 K / 3 E^ Unicode (UIF-B)  - 
6-60 插入 绑 定 字段 全 reply.php 网 页 


(3) 在 本 页 面 中 添加 两 个 隐藏 区域 ， 一 个 为 redate， 用 来 设 定 回 复 时 间 ， 赋 值 等 于 <?php 
date default timezone set('Asia/Shanghai);echo date("Y-m-d h:1:s");?>; 另外 一 个 是 passid， 用 
来 决定 是 否 通过 审核 的 一 个 权限 ， 赋 值 为 0 时 ， 怠 自动 通过 审核 ， 如 图 6-61 所 示 。 


尾 性 
AI FS x eft 

ÍB (V) lai’ );echo date("T-m-d h:i:s");?2| 多 
EIE 


N] eren 
iB o 98 


图 6-61 设置 “隐藏 区域 ”两 个 字段 的 属性 


(40 单 击 “服务 器 行为 ”面板 上 的 外 按钮 ， 在 弹出 的 染 音 中， 选择 “更 新 记录 ”命令 ， 
如 图 6-62 所 示 ， 用 于 根据 留言 内 容 对 数据 库 中 的 数据 进行 更 新 。 


+ 一 THRE. n 


重复 区 域 


记录 和 集 分 页 d 
显示 区 域 d 


显示 记录 计数 d 
动态 女 本 i 


HARR 
更 新 记录 
删除 记录 
动态 表单 元 素 > 
用 户 身 份 验证 > 
XSLT 转换 


编辑 服务 器 行为... 
新 建 服务 器 行为 ... 
获 职 更 多 服务 器 行为. .. 


- 


6-62 选择 “更 新 记录 ”命令 


PHP 


(50 在 打开 的 “更 新 记录 ”的 对 话 框 中 ， 按 如 图 6-63 所 示 进 行 更 新 设置 。 


s EH: | forml 


' 使用" FORM. ID 作为 “整数 AENEA ERE 

, subject * FORM. subject AB d 

i content 从 FORM. content' GREEN =p 

LUN. b reply 获 职 值 作为 “ 交 本 

, 获取 值 作为 “日 期 

获取 值 作为 “日 期 
A UE 

'passid $us FORM. dns, ARHMBTEN WE 


(B: | FORM. ID v 
gem. | 整数 Y 四 主妇 
在 更 新 后 ， 转 到 : admin. php | 


6-63 ”设置 “更 新 记录 ”对 话 框 
(6) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 这 样 束 完成 了 回复 留言 页 面 的 设置 。 


SAEC 删除 留言 页 面 


删除 留言 页 面 delbook.php， 其 功能 是 将 表单 中 的 记录 从 相应 的 数据 表 中 删除 。 页 面 设 计 
效果 如 图 6-64 所 示 ， 详 细 说 明 步 骤 如 下 。 


Qar- o- [gi (o sme thA GO S-i 
Hte an CECHI (D. 17 ghaak/delhoek. php?TEnl 


Tunt —— Bm AEREA ^o 311.0722 03:26:46 


mre | |] | tk 
Sa: ] | - 7-1 1g LE 
EEE] MEM ILE (2011-07-12 
EAE Hima |o MESI: [127.0.0.1 
€wARTA: (test 

HE AREAS 


WEAF: 


EERW: | 过 是 回复 测试 


FAm t 000-1 2345878 
RR: o0:0-12)49578 


EFA :GESEMS EEEN 


ewed FETE RERNA 


6-64 ”删除 留言 负面 效果 


(1) 打开 delbook.php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 [出 按钮 ， 在 弹出 的 选项 中 ， 选 择 
“记录 集 (但 询 )” 命 令 ， 在 弹出 的 “记录 集 ” 对 话 杠 中， 进行 如 下 设置 。 
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第 6 章 CHAE ESI 


D 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 和 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 gbook。 

3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 gbook。 
4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

5) 设置 “筛选 ”的 方法 为 : ID = URL 参数 ID. 

再 单 击 “确定 ”按钮 后 就 完成 设 定 ， 如 图 6-65 rn. 


6-65 设置 “记录 集 ” 对 话 框 


(2) 绑 定 记录 集 后 ， 再 将 记录 集 的 字段 插入 至 delbook.php 网 页 的 各 说 明文 字 后 面 ， 如 
图 6-66 所 示 。 

(3) 在 delbook.php 的 页 面 上 ， 单 击 “ 服 务 器 行为 ”面板 上 的 国 按钮 ， 在 弹出 的 菜单 
中 ， 选 择 “ 删 除 记录 ”命令 ， 如 图 6-67 所 示 ， 用 于 对 数据 表 中 的 数据 进行 删除 操作 。 


局 C: wpachevht doesAgbookvdelbook. php -0x 


首页 | 新 闻 动 态 | 信息 服务 | 信息 知识 | 信息 产业 | HAMD | #488 | 联系 我 们 
您 的 位 置 一 一 册 除 留言 现在 的 时 间 是 : gu 
NN UTE 
aede. AIR Ce OE CE ET DC NC RA S E- HeJ . 
| weNBSsmDeR R De: za 文档 类 型 : PHP 
留言 时 间 : |l[Rs.datel ERR 
BS : s. subject 3 - 
{Rs. content] ^ pr d 
留言 内 容 : c3 3 显示 区 域 上 
eus i 显示 记录 计数 , 
回复 内 容 : | {Rs. reply} u 动态 文本 
插入 记录 
更 新 记录 
m" 动态 表单 元 素 
ud n MN o REE S 用 尸身 份 验证 
: 客户 电话 : 010-12345678 ; XSLT 转换 
p : 编辑 服务 器 行为 
: 联系 人 : 李 先 生 ”联系 我 们 : ~ 新 建 服务 器 行为... 
< Jill ^ ps 
body> ONES T86 x 469v 127 K / 3 P Unicode (UTF-8)) — | 获 职 更 多 服务 器 行为 ，， 
iva IM v. iJ ^ 
6-66 字段 插入 全 delbook.php 网 页 6-67 选择 “删除 记录 ”命令 


(40 打开 的 “删除 记录 ”对 话 框 中 ， 设 置 效 来 如 图 6-68 所 示 。 


PHP 


首先 检查 是 天 已 定 兴 变量: 
连接 : 

表格 : 

主键 列 : wv [v] 数值 

主键 值 : wv [ID 

册 除 后 ， 转 到 |: 


图 6-68 设置 “删除 记录 ”对 话 框 
(5) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 这 样 就 完成 了 删除 留言 页 面 的 设 定 。 


中 ”管理 系统 功能 的 测试 


留言 板 系 统 部 分 用 到 了 手写 代码 ， 特 别 是 留言 的 日 期 和 回复 日 期 ， 其 中 还 涉及 到 了 留言 
者 的 了 P 采 集 ， 为 了 检查 开发 系统 的 正确 性 ， 需 测试 留言 功能 的 执行 情况 。 


6.54 


具体 的 前 台 测 试 步骤 如 下 。 
(D 打开 IE 浏览 器 ， 在 地 址 栏 中 输入 http:/127.0.0.1/gbook/， 打 开 index.php 文件 ， 如 
图 6-69 所 示 。 
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wm | FHS MEE a|] 
BOISE EINE ERTDETS A: 2001.07-22 03-02-16 

e ix 

TUR ET FEL ERE UOUA . UR AANE. Uen- Hiire. 

EF IHAN 

D WAM: heri 

3I? OU. BAR uu RATE: 
这 是 种 地 用 的 
PRA. BEERE 


IFANE HEST 


WAMA: 00-1z3456T8 
RE:nDIniTA 


BEAIERS M sel d 
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6-60 ”首页 效果 
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6-70 


(3) 开始 检测 留言 板 功能 ， 在 “留言 主题 ” 栏 中 填写 “开始 检测 留言 板 功 能 ”， 


留言 页 面 效 采 
在 “ 留 


言 内 容 ” 


栏 中 填写 “如 果 成 功 ，gbook 数据 表 中 将 添加 刚才 写 入 的 内 容 ”。 


填写 完 后 ， 单 击 


“提交 ” 投 钮 提交 ， 此 时 打开 index.php 页 耐 ， 可 以 看 到 多 了 一 个 刚 填写 的 数据 ， 如 图 6-71 


所 示 。 
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问 数 据 表 中 添加 的 数据 


PHP 


"T 
(1) 打开 IE 浏览 器 ， 在 地 址 栏 中 输入 http//127.0.0.1/gbook/admin login.php, #1 FF 
admin login.php 文件 ， 如 图 6-72 所 示 。 


(2) 在 网 页 的 表单 对 象 的 文本 框 及 密码 框 中 ， 输 入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “ 登 
x" gH. 


Jd 后 台 管 理 -Nicrosoft Internet Explorer 
THF AmE EAV 收藏 以) IAM 帮助 0 


QAE- 加 -加 国名 à PRR J4dEEx €) 向 - 四 四 和 

地 址 QD) Æ] http: //127. 0.0. l1/gbook/admin login. php MISES 链接 O SnagIt Ey 
留言 板 管理 系统 后 台 
用 户 ， admin 
密码 ， admin| 


Eea 


(MD Internet 


6-72 后台 管理 入 口 


G) 如 果 在 第 二 步 中 填写 的 登录 信息 是 错误 的 ， 浏 览 磊 融会 园 到 主页 面 index.php; WR 


输入 的 用 户 名 和 密码 都 正确 ， 则 进入 admin.php 页 面 。 在 这 里 输入 前 面 数据 库 设置 的 用 户 
admin 和 密码 admin 时 ， 转 到 admin.php 页 面 ， 如 图 6-73 所 示 。 


汪 后 台 管 理 = icroso ft Internet Explorer 

XO) EE EE) WO) IAM 和 帮助 Ht) 

QAE- O- nAIRE jux 6 3-3 BGL 
地 址 M) 8] http: //127. 0. 0. 1/gbook/admin. php 


所 输入 关键 词 搜索 wk 


首页 | 新 闻 动 态 | 信息 服务 | 信息 知识 | 信息 产业 | HAMN | 在 线 留言 | 联系 我 们 
你 的 位 置 : 管理 主页 面 


内 容 
如 果 成 功 ，gbook 数 据 表 中 将 添加 刚才 写 入 的 内 容 127.0.0.1 M ”回复 
Ws [BI 


Copytight(32011-2012 hbculture.com Inc.All rights reserved. 环 博 文化 版 权 所 有 D 


v 
p- 


开始 检测 留言 板 功 能 
test 这 是 测试 用 的 1270.0.1 


6-73 打开 的 留言 管理 页 面 
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m uoo —g e è ë p eiu E UN - 
GOG 809^ * - - - s EEEL : ran = | LE p7 EJ STL 
Doo 5 ev - e c E "" & 6 5 &B BD DUI i B p. m y 板 三 | 85 zt D 


(A) 选择 “删除 ”命令 ， 进 入 删除 页 面 delbook.phpp， 并 自动 将 删除 该 留言 信息 。 删 除 留 
言 后 返回 留言 管理 页 面 admin.php。 

(50 在 留言 管理 页 面 选择 “回复 ”命令 〈 本 次 测试 选择 编号 为 2 的 留言 进行 回复 )， 则 
进入 回复 页 面 replyphp， 如 图 6-74 所 示 。 


xa) Win Gon pwwo ING) don 
OaE- 2 HAG Ak ti 6 c3 [3 
HOEUD| bergo ZPO. Mebedlregir phett 


ENETTZ T 


mag a A HEAS: di 
E Marur: 
要 码 : [ CERKSENIDSE 这 i 
es amma: [2110726 
GEECBP EE Sur: EmO 


ENEE: #MEMEEET 
[EAA gno P WISIDRLA SAGA | 


E ITTTII 


TARL : 010-3466 8 
RR: 010125608 


FURA:GASM —— NESETI 


6-74 打开 的 回复 页 面 


(60 当 填 号 回复 内 容 “ 这 是 测试 回复 的 >， 并 单 击 “ 回 复 ” 按 钮 ， 将 成 功 回 复 。 
全 此 ， 完 成 了 网 站 留言 板 管理 系统 的 建设 ， 读 者 可 以 将 其 应 用 于 实际 网 站 的 建设 。 


第 区 4 章 ”投票 管理 系统 


本 章 主要 将 以 手写 代码 的 形式 开发 一 个 投票 管理 系统 ， 一 个 投票 管理 系统 大 体 可 分 为 3 


个 模块 : 选 紧 恒 块 、 选 票 处 理 模 块 以 及 结 末 显示 模块 。 投 票 管理 系统 首先 给 出 选 栋 选 题 ， 即 
供 投票 者 选择 的 表单 对 象 ， 当 投票 者 单 击 选择 投票 按钮 后 ， 选 紧 处 理 梗 其 被 激活 ， 对 服务 器 
传送 过 来 的 数据 做 出 相应 的 处 理 ， 先 判断 用 户 选 择 的 是 哪 一 项 ， 把 相应 字段 的 值 加 1 ， 然 后 
对 效 据 进行 更 新 ， 最 后 将 络 东 显示 出 来 。 本 章 的 核心 在 于 开始 以 手写 代码 的 形式 实现 PHP 
页 面 的 各 种 功能 ， 真 正 提 高 谈 者 的 程序 编写 能 


MATIE E 


主要 掌握 以 下 知识 点 : 


(7 投票 管理 系统 站 点 的 设计 

O 投票 绾 理 系 统 数 据 库 的 规划 
O 计算 投票 的 方法 

© 防止 刷新 的 设置 


投票 管理 系统 


| Section 


系统 的 整体 设计 规划 


改 票 管理 系统 可 以 分 为 3 个 部 分 的 页 面 内 容 ， 一 是 计算 投票 页 面 ， 二 是 显示 投票 结果 页 
面 ， 三 是 用 来 提供 选择 的 页 面 。 本 章 制 作 的 投票 管理 系统 总 共有 4 个 页 面 ， 页 面 的 功能 与 文 
件 名 称 如 表 7-1 所 示 。 


表 7-1 投票 管理 系统 网 页 设计 表 


需要 制作 的 主要 页 面 页 面 名 称 Jj 能 


开始 投票 页 面 访问 者 开始 进行 投票 的 页 面 
计算 投票 页 面 对 访问 者 提交 的 数据 进行 统计 并 向 数据 库 增加 数据 的 功能 页 而 


显示 投票 结果 页 面 voteok.php 显示 投票 选项 比例 和 总 显示 投票 的 最 终 效 果 页 面 
票 失 败 页 面 sorry.php 投票 失败 转 癌 的 页 面 


将 要 制作 的 投票 管理 系统 的 网 页 及 网 页 结构 如 图 7-1 所 示 。 


投票 管理 系统 


计算 投票 页 面 显示 投票 结果 页 面 


sorry.php 


图 7-1 投票 管理 系统 网 页 结构 图 


2 页 面 设计 规划 : 


根据 介绍 的 投票 管理 系统 的 页 面 设计 规划 ， 在 本 地 站 点 上 建立 站 点 文件 夹 vote， 将 要 制 
作 的 投票 省 理 系 统 的 文件 夹 和 文件 如 图 7-2 所 示 。 


voteadd.php voteok.php 


ta 
3r) WEE Fem Ami IBS) Mion 
QsE:- 2 T "cx m- 
ét an m Ei gachsVbldectiveta 
E XITERHEUS 
I 


p sst—TETME 
[t] Tec Tr em cmm gl 
Tab 


io] Xn 


图 7-2 站 反 规 划 文 件 夹 和 文件 
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役 轩 管理 系统 的 页 面 共 4 个 ， 包 括 开始 投标 页面、 计算 投标 页面、 显示 投 时 结果 页 面 以 
及 投票 失败 页 面 。 计 算 投 票 页 面 voteadd.php 的 实现 方法 是 接收 vote.php 所 传递 过 来 的 参数 
后 执行 累加 的 功能 。 为 了 保证 投票 的 公正 性 ， 本 系统 根据 IP 地 址 的 唯一 性 ， 设 置 了 防止 页 
面 刷 靳 的 功能 。 开 始 投票 页 面 和 显示 投票 结束 页 面 的 设计 如 图 7-3 和 图 7-4 所 示 。 


CE Aud Nicrosoft Internet Explorer mx 
xmo wm EEY «mo IAS) Who m | 
9 o ida Prr 5ema& e G LGC 
"OI M) http //127.0 D Y/vote/vote pto —oxwüiwt v Eaa us Gss: w 
- Ps ^| 
PHP 投 票 系统 É 投票 主页 面 一 Nicroso ft Internet Explorer PE) 
; : TFP AmE 查看 WW) wA IAT) 大助 0 
公平 AE WE 分析 : -d 
QmB- O- itf») sSx wx eA- BL 
地 址 (0) 外 http://127.0.0. l/vote/voteok. php ho SEE 链接 © SnagIt gj 
MERR t t 冰 投 票 只 而 投票 一 次 
你 投 的 选项 是 : 
9 A 
B 
c 
© D 
(8X) (39) 
Copyright 9 2011. MiCulture em Ine. Allo rits reserved PE Ti MEAN 2 
] o , Inte 
s AE 人 HH Z L H -= HH 4E 
7-3 ”开始 投票 页 面 7-4 ”显示 投票 结果 页 面 


E 数据 库 设 计 与 连接 


本 市 主要 掌握 投票 官 理 系 统 数 据 库 的 连接 方法 。 投 票 管 理 系 统 的 数据 库 主要 用 来 存储 投 
昧 选项 和 投票 次 数 。 


vens 数据 库 设 i | 


发 票 管理 系统 需要 一 个 用 来 存储 投票 选项 和 投票 次 数 的 数据 表 vote 和 用 于 存储 用 户 IP 
地 址 的 数据 表 ip. 

制作 的 步骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL”， 进 入 MySQL 数据 库 的 管理 面 
板 ， 如 图 7-5 所 示 。 


(2) 单 击 工具 栏 的 Crate 〈 增 加 ) 按钮 ， 并 在 打开 的 下 拉 某 单 中 单 击 选择 “Database 
(数据 库 )” 命 令 ， 如 图 7-6 所 示 。 


CN i 生态 | 
E ting Started 2288 

Ed Create rure datione 

bd Manage excitrg database) 
Calatase Tools 


en 30 urp 
G Manage un 
Heip and Support 

M) CX Murder 2000 hip piem 

Wi Magl reference 
| Internet Resources 
四 mb EE 
rp mem f) SOL Manager 2007 home page B. sapor Corte 


QR 50L ntarager 2007 omrana documentation 4i SOC Manager 2007 FAQ 


Scheduled Event 
UDF 
Report 


Favorite Guerry 


7-5 打开 MySQL 数据 库 管 理 界面 7-6 单 击 选 择 “DataBase” 命 令 


(3) 打开 “Create Database Wizard (建立 数据 库 问 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
“vote”, 然后 再 单 击 Next 《下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 ， 如 图 7-7 所 示 。 


Create Database Wizard 
Create Database 
Specify the name for a new database 
Welcome to the Create Database Wizard! 
This wizard allows you to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SQL statement for creating the database and execute it 
on MySQL server. 


Database name vote] 


Register after creating 


7-7 输入 数据 库 的 名 称 “vote” 
(4) 设置 MySQL 数据 库 的 属性 设置 如 表 7-2 所 示 ， 连 接 设置 如 图 7-8 所 示 。 然 后 再 音 


击 Next (下 一 步 ) 按钮 ， 继 续 下 一 步 有 的 设置 。 


表 7-2 数据 库 属性 设置 
Host name localhost Port 3306 


User name root 


Password admin 


PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


Create Database Wizard 
Create Database 


Set connection properies for a new database 


Host name localhost 


User name 


Password 


Character Set Lise server settings 


Collation 


[ ]use tunneling 


Tunneling 
*; SSH tunneling HTTP tunneling 


图 7-8 连接 设置 
(5) 打开 新 建 数据 库 的 SQL 语句 提示 创建 数据 库 vote, Fifa Next (下 一 步 ) 按 
钮 ， 如 图 7-9 所 示 。 


Create Database Wizard 
Create Database 
Result SQL statement. Click the Finish button to create a new database. 


Result SOL statement:: 
CREATE DATABASE "vote'; 


如 有 | 


Click "Finish" to create the database. 


j Cancel 


图 7-9 完成 设置 
(6) 单 击 Finishn〈 完 成 ) 按钮 ， 打 开 注 册 数 据 库 的 设置 画面 ， 选 择 utf8 字符 集 及 人 徐 体 中 
文 版 的 GB2312 版 ， 其 他 的 保持 默认 值 ， 如 图 7-10 所 示 。 


Database Registration Info 


Display Options Host name localhost {v Port 3306 $ 
[© Directories 
fl Logs 

(f$ SSH Tunneling 
Ill HTTP Tunneling Database name 
Data Options 


User name 


Password 


Database alias vote on localhost 


Client charset utfg| v 


Font charset GB2312 CHARSET (Simplified Chinese characl w 


图 7-10 选择 简体 中 文 


E EE S 


CI) 单 击 OK 确认 ) 按钮 ， 完 成 数据 库 vote PESE LE. 

数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 分 别 是 vote. 
ip。 建 立 数 据 库 后 ， 接 着 再 按 左 边 的 “Connect to Database. 〈 连 接 数 据 库 )” 图 标 总 ， 将 其 连 
接 上 。 这 两 张 数据 表 的 字段 结构 内 容 说 明 如 下 。 

CIO 建立 数据 库 vote 后 ， 用 局 标 右 键 单 击 选 择 “Table CERO" Am, ÆHF RA 
中 ， 单 击 选择 “New Table JIRO” ME, WK 7-11 所 示 。 


ir Create now table 


[P^ Create new database object 


g Execute query 


$5 Manage permissions 


SA Manager 2007 help system 


MySQL reference 


7-11 开始 建 数据 表 


(2) 数据 库 右 方 夯 面 会 出 现 新 建 数据 表 Table 的 设置 区 域 , 含有 “Table (表格 )”、 
“Fields (内 容 )”、“DDL (驱动 )”3 个 选项 卡 ， 先 在 “Table (表格 )” 中 输入 数据 表 名 
vote， 如 图 7-12 所 示 。 


Ss New Table — [vote on localhost] 


D Table |Fields | DDL 


Table Properties 
E vote on localhost [vote] w 
Table name vote| 
c — E 


Storage Options 
学 Compile Storage engine MyISAM {v 
9) Show SQL help Row format DEFAULT v 
Restore default size | Min. rows 


^|. Max. rows 


0 
0 
7 Auto increment value 0 
0 


z Average row length 


<>< >< >< ><> 


; Size for index key blocks 0 
- [C] Check sum [C] Delay key write 
[ ]Pack keys C] Temporary 


Character Sets | File Options | Merge Table Options | Federated Table Options 


Collation Default v 


7-12 输入 数据 表 名 vote 
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(3) 然后 再 切换 到 “Fields (内 容 )” 选 项 卡 中 ， 输 入 数据 域名 以 及 设置 数据 域 位 的 相关 
数据 ， 如 图 7-13 所 示 。 对 投票 系统 页 面 (?) 内 容 做 一 个 全 面 的 分 析 ， 设 计数 据 表 vote 的 字 
段 结构 如 表 7-3 所 示 。 


主题 编写 


表 7-3 投票 数据 表 vote 字段 结构 


| wmm | n | 5 
[m | vom | o | a’ 
ENCKENEE : 


e Table — [vote] — [vote on localhost] 


| [3 vote on localhost [vote v 


| EŞ vote 


- 


[a] Refresh 
| 学 Compile 
Qs Grants on table 
cea Print 
©) Show SQL help 
dh Table Editor options 
回 Restore default size 


-] 


Tools 


Ei Truncate table 


Field Type | Size |Preci...| Mot... Default Comment 


INTEGER |11 0 Null 


7-13 创建 的 vote 数据 表 


(4) 为 了 方便 后 面 系 统 开发 的 需要 ， 事 先 在 vote 数据 表 里 加 入 4 个 投票 的 数据 ， 单 击 
“Date《〈 数 据 )” 选 项 卡 ， 在 数据 表 中 手动 加 入 名 为 A~D 的 4 个 选择 模式 ， 如 图 7-14 所 示 。 


æ Table — [vote] - 


| [3 vote on localhost [vote v 


| Ef) vete 


General 


ig] Refresh 

学 Compile 

Qs Grants on table 

caa Print 

©) Show SQL help 

d Table Editor options 
回 Restore default size 


g 


Tools 


E Truncate table 


A 


[vote on localhost] 


i Properties | Fields || Indices | Triggers | Data | Dependencies | DDL | 


IPEE Heka HM = E 


column 


Drag a column header here to group br that 


| Grid View | Form View | Print Data 
Records fetched: 4/4 | | | JILIMIT. D, 1000 


图 7-14 输入 投票 选择 模式 
(50 创建 ip 数据 表 ， 用 于 限制 重复 投票 使 用 ， 输 入 数据 域名 称 以 及 设置 数据 域 位 的 相 


关 数 据 ， 如 表 7-4 及 图 7-15 所 示 。 


X 
主题 编号 
SERI ip HEHE 


ISES 
J 


Æ Table - [ip] - 


^l | Properties | Fields |Indices | Triggers | Data | Dependencies | DDL 
Field Name Field Ty... Size | Pre... | Not... Default Comment 


X 7-4 


字段 名 称 


ip 数据 表 字 段 结构 


voteip 


Object 


vote on localhost [vote v 


Ef ip v 


数据 库 创建 


以 及 插入 等 操作 


1.2.2 


在 Dreamweaver CS 5.5 中 创建 一 个 “投票 系统 


General = 


ig Refresh 
学 Compile 


e» Grants on table 


©) Show SQL help 

d Table Editor options 

加 Restore default size 
Tools 


E Truncate table 


"T 
完毕 ， 


o 


[vote on localhost] 


z 


E voteid VARCHAF 255 |0 Null 


图 7-15 创建 的 ip 数据 表 


对 于 本 系统 而 言 ， 痢 技术 是 如 何 用 手写 代码 的 形式 实现 数据 库 的 碍 询 


定义 vote 站 点 


定义 vote 站 点 | 


网 站 站 点 vote， 由 于 这 是 PHP 数据 库 


EL 


Ph, DOC E ELA DC AERA AS des ESTEE ETE Ue 7-5 Pro. 


47-5 站 点 设置 的 基本 参数 
站 点 名 称 vote 
本 机 根 目录 C:\Apache\htdocs\vote 
测试 服务 需 CAApacheMtdocsV 
网 站 测试 地 址 http:;//localhost/vote/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All UsersVApplication DataMySQLIAMySQL Server 5.5MataWote 
管理 账号 / 密码 root / admin 
数据 库 名 称 vote 


创建 vote 站 点 具体 操作 步骤 如 下 。 


(1) 首先 在 C:\Apache\htdocs 路 径 下 建立 vote 文件 来， 如 图 7-16 所 示 ， 本 章 所 有 建立 
的 网 页 文件 都 将 放 在 该 文件 夹 下 。 


7PHP-^ 


* CzXÀpacheXhtdocs 
THFT 编辑 于】 SAV 收藏 以 ) IAM 大助 0) 
OFE- O- F| OLER DHR Em 


地 址 0) E C: apachevhtdocs 


«ges 


XE XPEXIES A 


mw] 重合 名 这 个 文件 到 
TE E: 
A 复制 这 个 文件 来 
Q 将 这 个 文件 夹 发 布 到 
Web D pholtyAdnin 


E IE MUT 
以 电子 邮件 形式 改 送 

2 Eie | de 

x HERITIXE ip 


&]index. html 1 KB HTML X 


HUE 1 THR 


7-16 ”建立 站 点 文件 夹 vote 


出 
打开 “管理 站 点 ”对 


(2) 354] De aN CS 5.5， 和 选择 来 
“让 点 ”一 “管理 站 点 ” 
话 框 ， 如 图 7-17 所 示 。 

(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 
有 已 经 定义 的 站 点 。 单 击 右 边 的 “ 狐 建 ”按钮 ， 打 开 
“站 点 设置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ” vote. 

“本 地 站 点 文件 夹 ”. 

如 图 7-18 所 示 。 


靖 点 设置 对 旬 vote 


C:\Apache\htdocs\vote\。 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweaver 
包含 两 个 部 分 ; 可 在 其 中 存 展 和 处 理 文 件 的 计算 机 上 的 本 地 文件 
二 < 以 用 可 在 其 中 将 相同 文件 发 布 和 到 web 上 的 服务 器 上 的 远程 文件 来。 


站 点 通常 


2011-7-11 18:57 
2011-7-29 1T:42 
2011-7-28 15:36 
2011-T-T 22:04 
2011-7-9 8:00 
2011-86-15 9:41 
2011-T-4 9:35 
2011-T-30 18:20 
2011-85-30 15:30 
2011-T-11 18:48 
2011-8-1 19:09 
2004-11-20 15:18 
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f& Rf EAE ERRAT Dreamweaver 3 A e ds Hi PEXECRU S ER 
站 点 名 称 : 
本 地 站 占 剖 件 来 ; | CApachelhtdocslvotel 5 


建立 vote 站 点 


并 单 击 “添加 服务 器 ”按钮 [由 ， 打 开 “ 基 本 >” 
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(40 单 击 列表 框 中 的 “服务 器 ”选项 ， 
选项 卡 ， 进 行 如 图 7-19 所 示 的 参数 设置 。 


QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


编辑 (E) 
复制 (P) 
HIER R) 

导出 (T) 


“管理 站 点 ”对 话 框 


票 党 理 系统 


“IRIRA”: vote. 
“连接 方法 ” 本地/ 网络 。 
«Husa X LIC": C:\Apache\htdocs\。 
“Web URL”: http:// localhost/ vote/. 


Ardxmdi$ vote 


> 
E NNNM NN 
HER Bsasm[bo O ë 


p> ”高 级 设置 
连接 方法 :| 本 地 /网络 |» 
RA Brix 
Web URL: | http:// localhost/ vote] 


图 7-19 设置 “基本 ”选项 卡 
(5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 。 单 击 “维护 同步 
信息 ” 复 选 按钮 ， 在 “服务 右 模 型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL 来 表示 是 使 用 PHP JF 
发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 7-20 所 示 。 


站 点 设置 对 务 vote 


版 本 控制 
> 高 级 设置 [VI 维护 同步 信息 


O 保存 时 自动 将 净 件 上 传 到 服务 器 


O 自用 文件 取出 功能 
z Wi | 


MARR 


职称 | 


电子 邮件 地 址 : l 


测试 服务 器 
resnu [pema e] 


图 7-20 设置 “高 级 ”选项 卡 
(6) 蛙 击 “保存 ”按钮 ， 返 回 “ 服 务 占 ”设置 对 话 框 ， 再 单 击 选 择 “ 测 试 ” 复 选 按钮 ， 
如 图 7-21 所 示 。 


PHP 


站 点 设置 对 得 vote 


SE 您 将 在 此 位 置 选 择 学 载 web 上 的 页 和 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
版 本 控制 Internet 服务 提供 商 (ISP) 或 web SER. 


* ”高 级 设置 


注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完 成 此 步 又。 如 果 要 连接 到 | web 并 发 
布 页 面 ， 您 只 需 定义 一 个 远程 服务 器 即 可 。 


名 称 | 地 址 | 连接 | 远程 Wi | 
vote CiApachejhtdocs 本 地 /网络 [V M 


7-21 设置 服务 器 参数 


单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 
刚 所 设置 的 站 点 vote。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 枉 ， 这 样 束 完成 了 
Dreamweaver CS 5.5 测试 M 网 页 的 网 站 环境 设置 。 


设置 数据 库 连接 


完成 了 站 扣 的 定义 后 ， 接 下 来 就 是 投票 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 


1.2.3 


连接 设置 如 下 。 
CD 将 光盘 中 设计 的 本 章 静 态 文 件 复制 到 站 点 文件 夹 下 ， 打 开 vote.php 投票 首页 ， 如 图 
7-22 所 示 。 


Dw | ewm -1(8— — Oow CEES 
ELIT Ain Em Am PRm BAW ÉF KEC mae) Mihm 


EE MAS EE. Gm ux Wh LEAR e B © i 
ir -- de fat Hit NAF sharh : s , La 


rT 
4. ga UE DIT i 


PHP 投 票 系统 
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| MENU + + ERAT RE 


: Pow 
[k]fy qQ nu  -wwxaape ce K/ M Weed AD) 


[Om] Wm x 0 — v E3 v mz dmuuugmo| O 
ood mmx 加 E "Qo Bem 


- | > 
E 1 个 本 地 项目 镇 渤 中 , $E) 


7-22 打开 网 站 首页 
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(2) ARWR Ef] "ELIT — ARE $m. HA AE” DM. YE CUNG 
库 ” 面 板 ， 单 击 选 择 “+” 投 钮 ， 并 在 打开 的 染 单 中 选择 “MySQL 连接 ”命令 ， 如 图 7-23 
PIE 


»1. OWuEGEPRSUSR 站 点 。 
zo 选择 一 种 立 挡 类 型 。 
w 3. 设置 站 点 的 出 二 服 车 器 。 
4 ELEK + 按钮 创建 连接 。 


图 7-23 ”选择 MySQL 连接 


(3) Æ “MySQL 连接” 对话 框 中 ， 输 入 “连接 名 称 ” 为 vote, "MySQL 服务 器 ”名 为 
localhost, “用户 名 ”为 foot， 密 但 为 admin， 如 图 7-24a 所 示 。 选 择 所 要 建立 连接 的 数据 库 
名 称 ， 可 以 单 击 “ 选 取 ” 按 钮 浏览 MySQL 服务 左上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 数据 
FÉ vote， 上 其 体 的 设置 内 容 如 图 7-24b Bras. 


NySQL Erf 


zo 
es. Red 
sa: 
nx. 


performance schemaold 
we 


图 7-24 WE MySQL 连接 参数 


(4) Ah MR” A, MAS MySQL 数据 库 的 连接 是 否 正 硝 ， 如 果 正 确 则 会 出 一 个 
WME, WE 7-25 所 示 ， 这 表示 数据 库 连 接 人 设置 成 功 。 


f zr 


连接 铭 称 : 
MySQL 服务 器 : 


7-25 设置 成 功 


单 击 “ 确 定 ” 投 钮 ， 返 回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 如 
图 7-26 所 示 。 


数据 库 eme | 服务 器 行为 | = 
+ 一 TEEN. PHP 会 
日 vote 
E-Eà MEn 
"e TE enn 
日 m vota 


Lo -W ID (nt 11 必需 的 ) 
A Zn item (varchar 50 必需 的 ) 
Pr zs vote (int 20 JB 

B) X 视图 

bd. Nus 


7-26 ” 绑 定 的 数据 库 


投票 管理 系统 页 面 设 计 


在 投票 管理 系统 中 ， 需 要 重点 设计 的 页 面 是 开始 投票 页 面 vote.php 和 投票 结果 页 面 
voteok.php。 计 算 投票 页 面 voteadd.php 是 一 个 动态 页 面 ， 没 有 相应 的 静态 页 面 效 果 ， 只 有 累 
加 投票 次 数 的 功能 


/.3.1 开始 投 EX 设计 


开始 投票 页 面 vote.php 主要 是 用 来 显示 投票 的 主题 和 投票 的 内 容 ， 让 用 户 进行 投票 ， 然 


后 传递 到 voteadd.php 页 面 进行 计算 。 

许 细 的 操作 步骤 如 下 。 

d) 打开 刚 创 建 的 vote.php 页 面 ， 输 入 网 页 标题 “开始 投票 页 面 ” 执行 采 单 “文件 ” 
一 “保存 ”命令 ， 将 网 页 保存 。 

(2) 在 刚 创建 背景 图 像 的 单元 格 中 ， 执 行 末 单 “插入 记录 ”一 “表单 ”一 “表单 ” 合 
令 ， 再 执行 染 单 “插入 记录 ”一 “表格 ”命令 ， 在 表 蛙 中 插入 一 个 3 行 2 列 的 表格 ， 并 在 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


Cr LA-EESS 


dbHASTTCR MAWR” — “RE” — “Awk”, 插入 一 个 单 选 按钮 ， 然 后 在 “ 属 
性 ”面板 中 选择 单 选 按钮 ， 将 它 命 名 为 ID， 如 图 7-27 所 示 。 


ken 
[s] — WU 0 初始 状态 OB C 类 加) > 
OREP (0 


7-27 设置 “ 单 选 按钮 ”名 称 
(3) 执行 菜单 “插入 记录 ”一 “表单 ”一 “按钮 ”命令 ， 插 入 两 个 按钮 。 一 个 是 用 来 提 
区 表单 的 按钮 ， 命 名 为 “投票 ”， 男 外 一 个 是 用 来 查看 投票 结果 的 按钮 ， 命 名 为 “查看 ”。 效 
果 如 图 7-28 所 示 。 


bc C:\ipache\htdocs\vote\vote. php* z [mls 


PHP 投 票 系统 
公平 ”公正 WE 分 析 


:请 你 投票 + t t 本 投票 只 可 投票 一 次 


3 7596 (335) 
I4. 8696 (287) 
* 

4 Lb 3 H 


v 


X " "aio <tr> <td> Qabel?Knput) [k] Q 100€ — «661 x 4T2v 42K / 1 15 EXE es - 
图 7-28 插入 两 个 按钮 效果 图 


(4) 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 国 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 输 入 设 定 值 ， 如 图 7-29 Bras. 


名 称 : Rsvote | 


连接 : vote v 
Milvote v 


列 : 9 em O 选 定 的 : 


URL EMI 


排序 : | 无 


7-29 ”设置 “记录 和 集 ” 对 话 框 
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(5) 绑 定 记录 集 后 ， 将 记录 集中 的 字段 插入 全 vote.php 网 页 的 适当 位 置 ， 如 图 7-30 所 示 。 


| 7595 (335) 
UNE = 
' 你 投 的 选项 是 : 

Q [Revate.item?| 


一 


图 7-30 ”记录 集 的 字段 插入 至 vote.php 网 页 
(6) 单 击 “ 单 选 按钮 ” 将 字段 ID 绑 定 到 单 选 按钮 上 ， 绑 定 后 在 “ 单 选 按钮 ”的 属性 面 
板 中 的 “ 选 定 值 ” 中 添加 了 插入 ID 字段 的 相应 代码 为 <?php echo $row_Rsvote[TD']; ?>， 如 
图 7-31a. b 所 示 。 


at: 
HEB: [Hp echo Sron Ravotel IN 1; 97 


单 选 按钮 姐 : "ID" 在 RE “forni” v 
选 职 值 等 于 : <?php echo $row Rsvote[' ID ] P4 


b) 
图 7-31 插入 字段 到 单 选 按钮 
CD 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 命令 ， 单 击 vote.php 页 面 中 的 表格 ， 如 网 7-32 
所 示 。 


TS esas E—9— ————— — $$ RP] M ss E 
你 控 的 选项 是 ， 


1 
1 
| [S eee-E | 
| 


TT TT TT 


图 7-32 选择 要 重复 的 区 域 


(8) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 选 
$E "ED BU sp, HA] 7-33a 所 示 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 定 一 页 显示 
Rsvote 记录 和 集中 的 所 有 记录 ， 如 图 7-33b 所 示 。 


PHP 投 票 系统 


公平 2E WE 分析 


: MPRA 1 4 EBERENBE-II I | EEEE 


[; senimG*. 
EL. EERSNSWIN, 


3 i E uM MI 
LL Gabler ir A Eora P r a IS UENMSCEINEOGSERGCOUDN 19 
as — sa | 
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cx &EmcEU vE | 


图 7-33 设置 “重复 区 域 ” 对 话 框 
(9) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 ， 如 图 7-34 所 示 。 


T C:\Apache\htdocs\vote\vote. php -0x 
ETA vote. php 


公平 ”公正 WE E 


:请 你 投票 + + 本 投票 只 可 投票 一 次 


: 7596 (335) 

lik R = 8636 (287) p 
HE BE 
|O leweiem | 


| : 
<body> «table? <tr> <td> <form#forml > <table> [À | mq 661 x 410v 43 K / 1 b Unicode (UTF-8) — - 
V M 7 
图 7-34 设置 重复 后 的 效果 


(10) 在 vote.php 页 面 中 ， 将 鼠标 放 在 表格 中 ， 在 “标签 选择 右 ” 上 单 击 <form> 标 签 ， 
并 在 “属性 ”面板 设置 表单 <form1l> 的 “动作 ”为 设置 投票 数据 增加 的 页 面 voteadd.php。“ 方 


f PHP + QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


ik" y POST. Auk 7-35 所 示 。 


尾 性 
[| 表单 ID 动作 voteadd. php | (o 目标 (7) v 类 [C0) 无 
A [formi 方法 |POST v 编码 类 型 v 


图 7-35 设置 表单 动作 

重点 说 了 明 : PHP $_GET 变量 和 $_POST XE. 

1) $ GET € €. $ GET 变量 是 一 个 数组 ， 内 容 是 由 HTTP GET 方法 发 送 的 变量 名 称 
和 值 。$_GET 变量 用 于 收集 来 自 method="get" kÆ Fii. AA GET 方法 的 表单 发 
送 的 信息 ， 对 任何 人 都 是 可 见 的 (会 显示 在 浏览 器 的 地 址 栏 ) ， 并 且 对 发 送 的 信息 量 也 有 限 
制 (最 多 100 个 字符 ) 。 在 使 用 $_GET 变量 时 ， 所 有 的 变量 名 和 值 都 会 显示 在 URL 
中 。 所 以 ， 在 发 送 密码 或 其 他 敏感 信息 时 ， 不 应 该 使 用 这 个 方法 。 不 过 ， 正 因为 变量 显示 在 
URL 中 ， 因 此 可 以 在 收藏 夹 中 收藏 该 页 面 。 在 某 些 情况 下 ， 这 是 很 有 用 的 。 

2) $_POST € €. $_POST 变量 是 一 个 数组 ， 内 容 是 由 HTTP POST 方法 发 送 的 变量 
名 称 和 值 。$_ POST 变量 用 于 收集 来 自 method="post" 的 表单 中 的 值 。 从 带 有 POST 方法 
的 表单 发 送 的 信息 对 任何 人 都 是 不 可 见 的 (不 会 显示 在 浏览 器 的 地 址 栏 ) ， 并 且 对 发 送信 息 
的 量 也 没有 限制 。 

这 里 顺便 提 一 下 表单 的 验证 问题 ， 应 该 在 任何 时 候 对 用 户 输 入 可 以 进行 验证 。 客 户 端 的 
验证 速度 更 快 ， 并 且 可 以 减轻 服务 器 的 负载 。 但 任何 一 个 
流量 很 高 以 至 于 不 得 不 担心 服务 器 资源 的 站 点 ， 有 必要 担 E reens = 


属性 | 行当 | 标签 Gnput? 


心 站 点 的 安全 性 。 如 果 表 单 访 问 的 是 数据 库 ， 就 非常 有 必 sea 

要 采用 服务 器 端的 验证 。 在 服务 器 验证 表单 的 一 种 好 的 方 ok 
—-— 恢复 变 执 图 像 

式 是 把 表单 传 给 它 自 己 ， 而 不 是 跳 转 到 不 同 的 页 面 。 这 样 打开 浏览 器 窗口 


用 户 就 可 以 在 同一 张 表 单 页 面 得 到 错误 信息 ， 用 户 也 就 更 
容易 发 现 错误 了 。 

(11) 单 击 页 面 中 的 “查看 ”按钮 ， 选 择 “ 标 签 | 
(input)” 面板 ， 单 击 “ 行 为 ”面板 下 的 外 按钮 ， 在 弹出 oe 
的 菜单 中 选择 “ 转 到 URL” 命 令 ， 如 图 7-36 所 示 。 

(12) 打开 的 “ 转 到 URL” 对 话 框 ， 在 URL 文本 框 
中 输入 要 转 到 的 文件 voteok.php， 如 图 7-37 所 示 ， 然 后 单 
击 “ 确 定 ” 按 钮 ， 完 成 “ 转 到 URL” 设 置 。 


本 地 视图 v 


图 7-36 ”选择 “ 转 到 URL” 命 令 


NEED 


: |voteok. php | 


图 7-37 输入 “ 转 到 URL” 的 文件 地 址 


计算 iy mii 


计算 投票 页 面 voteadd.php， 主 要 方法 是 接收 vote.php 所 传递 过 来 的 参数 ， 然 后 再 进行 四 
加 计算 。 计 算 投 票 页 面 voteadd.php 只 用 于 后 台 计 算 用 ， 希望 投票 者 在 成 功 投 票 之 后 转 到 投 
票 结 果 页 面 voteok.php， 只 要 加 入 代码 header("location:voteok.php");$] voteadd.php 页 面 束 可 


以 完成 对 voteadd.php 页 面 的 制作 。 本 小 节 核 心 代码 如 下 : 


«meta http-equiv-"Content- Type" content-" text/html; charset-utf-8" /> 
<?php 
if (empty($_POST['ID'])){ 
echo "您 没 选择 投票 的 项 目 "; 
exit(0); 
HM/ 判 断 是 否 选 择 了 人 返 网 标的 选项 
else 


{ 


$ID-strval$ POST['ID']); 
/赋值 D 变量 为 上 一 页 传递 过 来 的 ID 值 


"on "on 


$conn = mysql connect("localhost","root"," admin"); 
/建立 数据 库 连 接 
if (!$conn) 
{ 
die( 数 据 库 连接 出 错 :' . mysql_errorO); 
j 
/如 末 数 据 库 连接 出 错 ， 显 示 错 误 


mysql_select_db("vote", $conn); 


/查询 vote 数据 


mysql query("UPDATE vote SET vote = vote + 1 WHERE ID = ".$ID.""); 


/根据 ID 更 新 数 表 vote， 并 目 动 加 一 


mysql close($conn); 


header("location:voteok.php ); 
// 转 到 voteok.php 
} 


重点 提示 : 
UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 
语法 

UPDATE table name 


SET column name - new. value 


WHERE column name = some value 


HEB SQL 对 大 小 写 不 敏感 ，UPDATE 5 update 等 效 。 
为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql_query( )FR Ze 


该 函数 用 于 向 SQL XE 


"s PHP+ QL*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


接 发 送 查 询 和 命令 。 


如 果 手 写 代 码 感 觉 到 困难 ， 请 打开 第 2 章 对 PHP 和 MySQL 数据 库 的 操作 章节 ， 进 行 详 
细 的 对 照应 用 。 在 手写 代码 的 时 候 切 勿 心烦 ， 只 有 细心 地 写 好 每 一 行 代码 ， 方 可 以 实现 其 功 


fE FUSAK hi o 


O SGRBERÁAURXEUET 


显示 投票 结果 页 面 voteok.php 主要 是 用 来 显示 投票 总 数 结果 和 各 投票 的 比例 结果 ， 静 态 
页 面 设 计 效 果 如 图 7-38 所 示 。 


b C: XApache*lht docs'*vote'*voteok. php* -= 口 X 


^ 


k]é) Q 100€ v615 x 292v 5 K / 1 ^ Unicode (UIF-5) — 
图 7-38 显示 结果 页 面 设计 效果 


COD 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 国 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ”对 话 框 中 ， 设 置 如 图 7-39 所 示 。 


7-39 ”设置 “记录 和 集 ” 对 话 框 


(20 再 次 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 办 按钮 ， 接 着 在 弹出 的 菜单 


投票 管理 系统 


中 ， 选 择 “ 记 录 集 (人 查询)” 命令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 局 级 ”按钮 ， 进 
入 高 级 编辑 窗口 ， 并 在 SQL 对 话 框 中 加 入 以 下 代码 : 

SELECT sum(vote) as sum 

/选择 vote EGET VERTES, BÉ sum() 用 于 计算 总 值 


FROM vote 
// 从 数据 表 vote 中 取出 数据 


如 图 7-40 所 示 。 


: Esl 


: [vote 


: SELECT sum(vote) as sum 
vote 


添加 到 SQL: 


SELECT 


WHERE 


ORDER BY 


预存 过 程 


7-40 ”设置 “记录 和 集 ” 对 话 框 


(3) 早 击 “人 确定” 按钮， 完成 记录 集 的 设置 。 绑 定 记 录 集 后 ， 将 记录 集中 的 字段 插入 到 
voteok.php 网 页 中 的 适当 位 置 ， 如 图 7-41 Bran. 


四 C:\Apache\htdocs\vote\voteok. php 


: em Enc sum}% {Rs.vote) 票 数 | : 


| 国 | 


& A 
body? <table> <tr> <td> <form... > Ly 584 x 289v 6 K / 1 $^ Unicode (UTF-8) 


7-41 字段 的 插入 全 voteok.php 


(4) 单 击 四 垣 按钮 ， 进 入 “代码 ”视图 编辑 页 面 ， 在 “代码 ”视图 编辑 页 面 中 找到 如 
下 代码 : 


PHP-* 


<?php echo $row. Rs['vote']; ?»/«?php echo $row. Rs1['sum']; ?> 


/相应 百分比 的 代码 


按 下 面 步 又 修改 此 段 代 人 码 。 
D 去 控 “/” 前 面 的 ?> 的 “/” 和 和 后面 的 <?php echo, AIT: 


<?php echo $row. Rs['vote']/ $row. Rs1['sum'] ?> 

2) 把 <?php echo 和 多 > 之 间 的 代码 用 〈) 把 它 给 括 上 ， 得 到 代 体 : 
<?php echo ($row_Rs['vote']/$row_Rs1['sum'])?>% 

3) 在 代码 后 面 加 入 *100， 得 到 代码 : 
<?php echo ($row. Rs['vote']/$row. Rs1['sum!]) *100?» 9c 


4) 在 代码 前 面 加 入 round， 在 *100 前 面 加 入 小 数 点 保留 位 数 4， 并 用 《〈) 括 上 ， 得 到 代 
(ET 
<?php echo round(($row. Rs['vote']/5row. Rs1['sum']),4)*100?* 96 
(5) 代码 修改 之 后 ， 因 为 控制 网 页 中 的 长 度 也 是 用 到 这 上段 代码 ， 所 以 将 这 段 代 但 进行 复 
制 ， 然 后 再 单 击 四 | 按钮， 切换 到 “代码 ”窗口 ， 选 择 <img> 中 的 width 的 值 将 其 代码 进行 业 
贴 ， 因 为 在 图 案 中 没有 用 到 小 数 点 的 设置 ， 所 以 将 代码 前 面 round 和 保留 位 数 4 删除 ， 得 到 
代码 为 : 


width="<?php echo round(($row. Rs['vote']/5row. Rs1['sum']),4)*100?» " 


这 样 ， 图 像 就 可 以 根据 比例 的 大 小 进行 宽度 的 缩放 ， 设 置 如 图 7-42 所 示 。 


To] C: A&pache'ht docsNvote'*voteok. php = EIX 


a: vote.php T 
— LI Lu Uuciriilu1- PUS - UII-— ^ 
83 «table wvidthsz"75$" borders"l" align="center" cellpaddings"0" E 


cellspacing="0" bordercolor="bl8a02" bgcolor="fff2bb"> 
<tr> 
<td height="20" colspan="3"><span class=" STYLE1l">&nbsp; <span 
clas3="STYLE6"> 投 票 结果 < /sp an></span></td 
LACES 
<tr> 
«td width="18$" height="25"><label><span classs"STYLE3"» 
&nbsp: <?php echo $row Rs['iten']; ?-«/span»-/label»«/td-» 
<td width-"495"5-&nbsp:czimqg src-"images/bar.qgif'" 
| height-"13" /> 


ll 


«span classs"STYLE3"- 
<?php echo round(($row Rs['vote']/$row Rsl['sum']),4)*100?-$ — 
«/span»«/td» 
«td width-z"335$" class=" STYLE3">&nbsp; <?php echo $row Rs['vote 
(3: 2 -3X!& mbsp; -td 


|< 


<form. . . > <table> <tr> «td» mg? 5 K # 1 f^ Unicode (UTF-8) 


图 7-42 设置 图 像 的 缩放 


(6) 单 击 [ 设计 | 榨 钮 ， 回 到 “设计 ”编辑 窗口 ， 加 入 “服务 器 行为 ”面板 中 “重复 区 
域 ” 的 命令 ， 选 择 voteok.php 页 面 中 需要 重复 的 表格 ， 如 图 7-43 所 示 。 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


投票 管理 系统 


T) C: XApache*ht docs\vote\voteok. php emp 
"nat vote. php 


7596 (351) = 
49% (170) = 


投票 结果 


| 投票 结果 | 
die [9g — — eso 


able»)? label? <span... > (R |d) Q (100 v584 x 289v 5 K / 1 $| Unicode (VIF-B) : 


图 7-43 ”选择 要 重复 的 区 域 
CI) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 选 
择 “ 重 复 区 域 ” 命 令 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 定 显 示 Rs 记录 集中 的 所 有 记 
ok, ll 7-44 所 示 。 


7-44 设置 “重复 区 域 ” 对 话 框 


(8) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先 前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

(9) 单 击 页 面 中 的 “返回 ”按钮 ， 选 择 “ 标 签 (input)” 和 面板 ， 再 单 击 “ 行 为 ”面板 上 
的 四 按钮 ， 在 弹出 的 菜单 中 选择 “ 转 到 URL” 选 项 ， 在 打开 的 “ 转 到 URL” 对 话 框 中 的 
URL 文本 框 输入 要 转 到 的 文件 “vote.php” 如 图 7-45 所 示 。 


打开 在 : Eann 


URL: wote. php Bit... 


7-45 输入 “ 转 到 URL” 的 文件 地 址 


"s PHP+ QL*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(100 单 击 “确定 ”按钮 ， 完 成 显示 投票 结 琳 页面 voteok.php 的 设置 。 测 试 浏览 效 末 如 图 
7-46 所 示 。 


A 投票 主页 面 ~ Nicrosoft Internet Explorer DER) 
THFT AEE SEM KRAO IA) E0 [7 


QAER- O-iX(at mk jux 四 | 办- Ema 
Htc 0) 4] http: //127.0.0. 1/vote/voteok. php —wo ceux Eea 链接 Qs 对 


图 7-46 显示 投票 结果 页 面 的 效果 


757 防止 页 面 刷新 设计 


一 个 投票 管理 系统 要 求 公 平 、 公 正 的 投票 ， 不 允许 进行 多 次 投票 ， 所 以 在 设计 投票 开始 


系统 时 ， 有 必要 加 入 防止 页 面 刷新 的 功能 。 

实现 该 功能 的 详细 操作 步骤 如 下 。 

(1) 打开 开始 投票 页 面 vote.php， 把 鼠标 放 在 表单 中 ， 执 行 菜单 “搬入 记录 ”一 “ 表 
单 ” 一 “隐藏 域 ”命令 ， 插 入 一 个 隐藏 字 上 段 voteip。 

(2) 单 击 隐藏 域 噶 图 标 ， 打 开 “ 属 性 ”面板 。 设 置 隐藏 域 的 值 为 <?php echo $ SERVER 
[REMOTE ADDR];?». 


/取得 用 户 IP 地 址 
如 图 7-47 所 示 。 
尾 性 = 
ANI parme Eh 
iB e) 多 


7-47 RA “KRE” (H 


(3) 将 实现 防止 刷新 的 程序 放 到 voteadd.php 页 面 里 面 ， 打 开 前 面 制 作 的 计算 投票 页 面 
voteadd.php， 在 相应 的 位 置 加 入 代码 ， 如 图 7-48 Dra» 


AEG) 编辑 (EF) 查看 (Y) HA (OE ”格式 (0) 命令 ([C) xc) 窗口 ARH 
C:\Apache\htdocs\vote\voteadd. php 
[代码 | 拆 分 | 设计 | | 实时 代码 | pz A 


Dw | eim | [B3 Oc CEEB) 


Ł 一 TRH: PP 


i G D C qi: file:///C|/Apache/htdoi 


L4 
v 


Pu 


你 


M UE e 


A s 
ue x 


om ip where voteid-'".$voteip."''"" 


i: 
& 


$ir 
// 如 果 值 为 真 ， 说 明 数 据 库 中 有 ?地 址 ， 已 经 投 过 村 


若 要 在 该 页 面 上 使 用 动态 数据 : 
1. 


2. 
3. 
4. 


请 为 该 文件 创建 一 个 站 点 。 
选择 一 种 立 档 类 型 。 
设置 站 点 的 测试 服务 器 。 
ENS G) 按钮 并 选择 记 


: 


e vote 


司 || 本 地 视图 区 


roteok. p. hp 


query ("INSERT INTO ip (voteid) VALUES ('".$voteip."')" 
y^ 只 有 则 将 ip 地 址 插入 到 ip 数 据 表 中 


« E f ui 


2 K/ 1 f? Unicode (UTF-8) 


if (enpty G- Li ID ])){ 
ne 没 选 择 投 票 的 项 目 “; 


H 1A ic TERRAN 
else 


图 7-48 加 入 防止 刷新 的 代码 


具体 的 代码 分 析 如 下 : 


$voteip-strval($ POST['voteip']); 
/赋值 变量 voteip 为 上 一 页 传递 过 来 的 voteip fH 


$con = mysql_connect("localhost","root","admin"); 
/建立 数据 库 连 接 
if (!$con) 

{ 

die( 数 据 库 连接 出 错 :". mysql. error0); 

j 


// 如 果 数 据 库 连 接 出 错 ， 显 示 错 误 


mysql select. db("vote", $con); 

/得 询 vote 数据 库 

$sql=mysql_query("select * from ip where voteid="".$voteip.""); 
/以 voteid=voteip 为 条 件 查 询 数 据 表 ip 
$info2mysql fetch, array(S$sql); 

/从 结 末 集中 取得 一 行 作为 关联 数组 info 

if($info==true) 
URENA, HHA EPA IP hk, CARIK 


{ 


j 


header("location:sorry.php"); 
// 转 到 voteok.php 
exit; 


else 


{ 


mysql_query("INSERT INTO ip (voteid) VALUES ('".$voteip.")"); 


header("location:sorry.php"): Un © | 山 个 Ti E eg | Er] 
n 


Connections 
images 
mdb 


i 3 sorry. php 
Lh vote.php 


voteadd. php 


o voteok. php 


T ^ 
J Mx 


a 
ZA 
MÀ 


o 
-—. 


IPHP+ 
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// 如 果 没 有 则 将 ip 地 址 插入 到 ip 数据 表 中 
} 


mysql close($con); 


(4) 完成 防止 页 面 刷新 设置 。 当 用 户 再 次 投票 时 ， 系 统 可 以 根据 IP 的 唯一 性 进行 判断 。 当 
用 户 再 次 投票 的 时 候 ， 将 转 到 投票 失败 页 面 sorryphp，sorry.php 页 面 设计 如 图 7-49 所 示 。 
d HIXXWe- Hicrosoft Internet Explorer 
ftc) RED SEM RR IAT 帮助 00 
GEE- O- NEO Ps TER 6 2-LGL 
Ea: 13 [d] http: //127. 0.0. L/vote/zorry. php v 国 革 到 Hs Qni p 


图 7-49 投票 失败 页 面 效果 


在 sorry.php 页 面 有 两 个 页 面 链接 ,“ 回 主页 面 ” 链 接 到 votephp. “查看 结果 ”链接 到 
voteok.php. 


投票 管理 系统 测试 


妇 票 管理 系统 设计 完成 以 后 ， 可 以 对 设计 的 系统 进行 测试 ， 按 下 (F12) 键 或 打开 IE 浏 
WASHA http://127.0.0.1/ vote/vote.php， 即 可 开始 进行 测试 。 测 试 步 骤 如 下 。 

(1) 打开 Dreamweaver 中 的 vote.php 文件 ， 按 下 (F12) 键 或 打开 IEhttp://127.0.0.1/vote/ 
vote.php， 即 看 到 开始 投票 页 面 效 果 ， 如 图 7-50 所 示 。 
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HIE E. 
QO A 
$ B 
O D 


(8X) (885 


Cesyright B 2011 Halise cea Ias ALl ripi rarervaed HETE ERAN 


DEG 8 | -] Pyme 


图 7-50 打开 的 开始 投票 页 
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(2) 不 选择 任何 选项 ， 


单 击 “ 投 票 ”按钮 ， 则 打开 提示 “您 
7-51 所 示 。 


您 没 选择 投票 的 项 目 "， 如 疼 


Jd http://1271. 0. 0. 1/vate/voteadd. php 


Nicrosoft Int... EBR) 
TH Sen EEM KE ITAM) TR)OD AY 
om- O- x 


i (5 sm TRR 6 0- 9c 
Hr m) [3 http: //127.0.0. 1/vote/voteadd. php 


您 没 选择 投票 的 项 目 


OW We Oa 加 


M Internet 
图 7-51 “您 没 选 择 投 票 的 项 目 ” 错 误 提 示 
(3) 单 击 投票 项 “ 单 选 按钮 ”项 中 的 其 中 一 项 ， 再 单 击 “ 投 票 ” 投 钮 ， 开 始 投票 。 
(4) 单 击 “ 投 票 ” 按 钮 后 ， 打 开 的 页 面 不 是 voteadd.php， 因 为 voteadd.php 只 是 计算 投 


票数 的 一 个 统计 数学 页面， 打开 的 页 和 面 是 显示 投票 结果 页 和 面 voteok.php，voteok.php 页面 是 
voteadd.php 转 过 来 的 一 个 页 面 ， 效 果 如 图 7-52 Bras» 


A 投票 主页 面 - Nicrosoft Internet Explorer 
TFT SHE SA0 收藏 IAM 帮助 0 


QAE- O- NAGAR wx e 


内- e BL 
地 址 0) 


< 输入 关键 词 搜索 MERA dm Osun (e 


æ http://12T.0. 0. 1/vote/voteok. php 


二 一 3448% 
20.69% 6 票数 
31.0396 9 票数 
13.79% 4 票数 


7-52 ”显示 投票 结果 页 面 效 果 
(5) 单 击 “ 返 回 ” 按 钮 ， 回 到 投票 页 面 vote.php "P. 
(6) 当 用 户 再 次 投票 时 ， 将 打开 投票 失败 页 耐 Sorry.php。 


d m-xw - 


Wicrozoft Internet Explorer 


THEO) RAD E GMa IAT WROD 


GKE- O NEG OR ttr 6 [DC mc 
HBIE C) AE] http://127.0.0. lvetefserry pip —— —5 cw M EJAN HE Qsan pr 
HFE, PERI—HAET , WTESHAA! 


BEND HESR 


aD Internat 


图 7-53 ”提示 已 经 投票 
22 EH 


经 过 上 面 的 测试 ， 说 明 该 管理 投票 系统 的 所 有 功能 已 经 开发 完毕 。 用 户 可 以 根据 需要 修 
改 投票 的 选择 项 ， 经 过 修改 后 的 投票 系统 可 以 适用 于 任何 大 型 网 站 的 开发 与 建设 。 


党 8 = BBS 论坛 管理 系统 


BBS (Bulletin Board Service， 公 告 牌 服务 〉 是 一 种 基于 Internet 的 信息 服务 系统 。 它 提 
供 了 公共 电子 白板 ， 每 个 用 户 都 可 以 在 上 面 发 布 信息 或 提出 看 法 。 本 章 将 学 习 使 用 PHP K 
Jj BBS 论坛 的 开发 方法 。BBS 论坛 通常 按 不 同 的 主题 划分 为 很 多 个 版 块 ， 按 照 版 块 或 者 栏 
目的 不 同 ， 可 以 由 管理 员 设 立 不 同 的 版 主 ， 版 主 可 以 对 目 己 的 栏目 或 版 块 进行 删除 、 修 改 或 
锁定 等 操作 。 


MATIE E 


HFA NAR: 


掌握 BBS 论坛 系统 的 功能 页 面 规划 

建立 BBS 论坛 系统 的 数据 库 

BBS 论坛 系统 中 新 增 主题 、 删 除 主题 、 回 复 主 题 的 方法 
BBS 论坛 系统 后 台 省 理 功能 的 开发 


45:85 BBS ERARA 


系统 的 整体 设计 规划 


BBS 主要 功能 是 通过 在 计算 机 上 运行 服务 软件 ， 人 允许 用 户 使 用 终端 程序 ， 通 过 Internet 
来 进行 连接 ， 实 现 用 户 消 有 息 之 间 的 交互 功能 。 系 统 的 开发 比较 复杂 ， 需 要 经 过 前 期 的 系统 规 
划 。 本 章 要 开发 的 BBS 论坛 管理 系统 页 面 的 功能 与 文件 名 称 如 表 8-1 Dra. 


表 8-1 BBS 论坛 系统 网 页 设计 表 


需要 制作 的 主要 页 面 页 面 名 称 功 能 
BBS 论坛 管理 系统 主页 而 显示 主题 和 回复 情况 的 页 面 
讨论 主题 内 容 页 面 主要 显示 讨论 主题 和 回复 内 容 的 页 面 
浙 增 讨论 主题 页 面 增加 讨论 主题 的 页 面 
回复 讨论 主题 页 面 对 讨论 主题 进行 回复 的 页 面 
后 台 版 主 登 录入 口 页 面 管理 员 登 录入 口 页 面 
后 台 版 主管 理 页 面 对 论坛 进行 管理 主要 页 面 
删除 讨论 页 面 删除 讨论 主题 的 页 面 
删除 回复 页 面 删除 讨论 回复 内 容 的 页 面 
修改 讨论 主题 页 面 upd_title.php 修改 讨论 主题 的 页 面 


下 面 要 制作 的 BBS 论坛 管理 系统 的 网 页 及 网 页 结构 如 图 8-1 所 示 。 
BBS 论坛 管理 系统 
index.php 


访问 者 登录 


m} 
时 
xu 
Jg 
ll 


D 
^ ML 


bbs add. php bbs reply. php admin. php 
del title. php del reply. php upd title. php 


图 8-1 BBS 论坛 管理 系统 结构 图 


content. php admin_login. php 


页 面 整体 设计 规划 


介绍 了 BBS 论坛 省 理 系统 的 整体 设计 规划 ， 在 本 地 站 点 上 建立 站 点 文件 夹 bbs。 将 要 制 


PHP 


作 的 系统 文件 如 图 8-2 所 示 。 


"CC:\Apache\htdocs\bbs 
AEG) AmE SEV 收藏 IAM 帮助 0) 


QmB- O- B| OBR (odx Cm. 加 文件 来 同步 


地 址 0) 全 C: \Apachethtdocsibbs 


文件 和 文件 夹 芷 务 â - .mmServerScripts - notes - Connections 


C3 创 娃 一 个 新 文件 来 
Q 将 这 个 文件 来 发 布 到 l KL :anin php 

Web images mdb PHP Script 
Eg HFHNHR 《> 11 KB 


| php admin_login. php | pup 因 bbs add.php | pup Im da _reply. php 


Qu Ru" x 


[ pup |S Be php PHP PES reply. php [PHP i le php 
ocCr1i cri oCcript 
《> RE (5 su 


11 KB 


E Sar php |_PHP wpati tle. php 
HP Script HP Script 
<I> 9 KB ar <l> 6 KBO "m 


EET 


14 个 对 象 


8-2 ”站 后 规划 文件 
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BBS 论坛 管理 系统 的 界面 要 求 简洁 明了 ， 尽 量 不 要 使 用 过 多 的 动画 和 大 图 片 ， 这 样 可 以 提 


局 BBS 论坛 的 访问 速度 。 要 制作 的 首页 面 和 详细 内 容 页 面 效 末 如 图 8-3 和 图 8-4 所 示 。 


ax) 
LA 


A 论坛 之 家 一 Nicrosoft Internet Explorer 
THF AmE SENO KEA IA) 和 帮助 0) 


QAE- O- [ài sk z O -52« 


Hir (0) 8] http: 7/127. 0. 0. 1/bbs/index. php? uL yra Hë Qseg: g 
E 2 ' 


i “PHP 论坛 管理 系统 


侈 发 表 话题 | 2€ Ho 
(» 3» | mk | awe | me| xa — 
BEC LL EEFRBB- 
Jc NN EN RN RN NN 


Copyright & 2011 www.hbculture.com Inc. åll rights reserved. 论坛 之 家 


(AMD Internet 


图 8-3 首页 的 美工 效果 


BBSitin E Ie 


TFT 编辑 下) SEV KEA IR() 帮助 0 
OAE- O- AAO RRO O-5 0 € 


HHE M) 4] http: //127. 0. 0. 1/bbs/ content. php?bbs, id-1 


A 论坛 之 家 一 Nicroso ft Internet Explorer DAR) 
" 


N 


| ; “| RANS 
d | | b 


讨论 主题 ，test 


Li 主题 内 容 : test 


发 表 人 : test TS 电子 邮件 © 主页 


回复 内 容 : test 


| V? 2011-6-07 È EZA © 主页 


Copyright @ 2011 www hbculture.com Inc.All rights reserved. 论坛 之 家 


8-4 ”详细 内 容 页 面 效果 


重点 提示 : 初学 者 在 设计 制作 过 程 中 ， 可 以 打开 光盘 中 的 源 代 码 (code 文件 夹 )， 找 到 
本 章 的 images 文件 夹 ， 其 中 有 已 经 编辑 好 的 图 片 。 


Section 


数据 库 设计 与 连接 


制作 BBS 论坛 管理 系统 的 数据 库 需 要 根据 开发 的 系统 大 小 而 年， 下 面 要 设计 用 于 BBS 
讨论 主题 的 信息 表 bbs_main， 用 于 回复 内 容 的 信息 表 bbs_ref， 最 后 还 需要 建立 一 个 管理 员 
进行 管理 的 信息 表 admin. 


sp 数据库 设计 


首先 建立 一 个 名 称 为 bbs 的 数据 库 ， 并 在 里 面 建立 管理 员 管 理 信息 表 admin、 讨 论 主题 
信息 表 bbs_main 和 回复 主题 信息 表 bbs_ref， 这 3 个 数据 表 将 作为 任何 数据 的 查询 、 新 增 、 
修改 与 删除 的 后 问 文 持 。 

制作 的 步骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL”, YEA MySQL 数据 库 的 管理 面 
板 ， 如 图 8-5 所 示 。 


PHP+ QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(2) 单 击 工具 栏 的 Create Gpr) 按钮 ， 并 在 打开 的 下 拉 荣 单 中 单 击 选择 “Database 
(数据 库 )” 人 命令， 如 网 8-6 所 示 。 


Get ting Started 


Hd Create new database 
E" Manage exito databases) 

Database Tools 
M" Exmcut SQL script 
© Mirage users 

Help and Support 
(à SA Manager 2007 hep system 
CA MEN reference 

3-1! Internet Resources 

fà SO. Manager 2007 home page Pa Support Cone 


G oa manager 2007 oine documeresson É aa Manager 2007 FAQ 


图 8-5 打开 MySQL 数据 库 管 理 界面 K|8-6 单 击 选择 “Database” 命 令 
ir 


(3) 打开 “Create Database Wizard (建立 数据 库 问 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
“bbs” 然后 再 单 击 Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 ， 如 图 8-7 所 示 。 


Create Database Wizard 
Create Database 
Specify the name for a new database 
Welcome to the Create Database Wizard! 
This wizard allows you to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SQL statement for creating the database and execute it 
on MySQL server. 


Database name bbs 


Register after creating 


图 8-7 输入 数据 库 的 名 称 “bbs” 


(4) 设置 MySQL 数据 库 的 属性 设置 如 表 8-2 所 示 ， 连 接 设 置 如 图 8-8 所 示 。 然 后 再 单 
i Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 


表 8-2 ”数据库 属性 设置 
Host name localhost Port 3300 


User name root 


Password admin 


ds E 汪 ;二 博取 BBS 论坛 管理 系统 


Create Database Wizard 


Create Database 


5et connection properies for a new database 


Host name localhost v Part 3308 7 


User name rant 


Manager m | 
— Manager 
| —— forMySQL [| Use tunneling 
lk. Tunneling 
s) SSH tunneling ( HTTF tunneling 


图 8-8 ERKE 


(5) 打开 新 建 数 据 库 的 SQL 语句 提示 创建 数据 库 bbs， 直 接 单 击 Next (下 一 步 ) 按 
钮 ， 如 图 8-9 所 示 。 


Create Database Wizard 
Create Database 
Result SOL statement. Click the Finish button ta create a new database. 


Result SoL statement: 
CREATE DATABASE bbs’: 


8-9 ”完成 设置 


(6) 单 击 Finish( 完 成) 按钮 ， 打 开 注 册 数 据 库 的 设置 画面 ， 选 择 utf8 字符 集 和 简体 中 


文 版 的 GB2312 版 ， 其 他 的 保持 默认 值 ， 如 图 8-10 所 示 。 


PHP 


Database Registration Info 


fei Options 
Display Options Host name Port 
[© Directories User name 

fV Logs 
qf SSH Tunneling Pagsword 

1i HTTP Tunneling Database name 
Data Options 


Database alias bbs on localhost 


Client charset (utta 


Font charset E: 2 CHARSET (Simplified Chinese characters: Iz 


8-10 选择 简体 中 文 


CI) 单 击 OK 确认) 按钮 ， 束 完成 了 数据 库 bbs 的 新 增 工 作 。 

数据 库 建立 后 ， 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 分 别 是 BBS 
讨论 主题 的 信息 表 bbs_main、 用 于 回复 内 容 的 信息 表 bbs_ref、 管 理 员 进行 管理 的 信息 表 
admin。 建 立 数据 库 后 ， 接 着 再 按 左边 的 “Connect to Database GEROER” Kir AKH 
连接 上 。 这 3 张 数 据 表 的 字段 结构 内 容 说 明 如 下 。 

(1) 建立 数据 库 bbs 后 ， 用 鼠标 右键 单 击 选择 Table 表格， 选项， 在 打开 的 采 单 中 单 
击 选择 “New Tabe GIRO” MẸ, WK 8-11 Dr 


SQL M 2007 for Ey bbs on localhost [bbs] fæ VO fx 


anagor 
Tw 3*5 Fr 23242:5S*5À5 9552229552 


i $ 1 Ai Xi d om Mu Ww [- 
iljieewe -| 3 ^W me Getting Started 


[he Create new database [ft Create rew table 


[iip Manage existing databases) l^ Create new database cbject 


E Execute SQL script [" 4 Execute query 


$a Manage permissions 


(à SA Manager 2007 help system 


te Cureeed To (à) Ma reference 
i — . hternet Resources 
ocunost eon on Iocanost rabies 0 
[Titas p S Manager 2007 home page 他- Support Contor 


@ sd Manager 2007 on-line documentation Q SOL Manager 2007 FAQ 


8-11. 开始 建 数 据 表 


(2) 数据 库 右 方 夯 面 会 出 现 新 建 数据 表 Tabe 的 设置 区 域 , 含有 “Table (表格 )”、 
“Fields (内 容 )”、“DDL (驱动 )”3 个 选项 卡 ， 先 在 “Table (表格 )” 中 输入 数据 表 名 
bbs main, AE 8-12 所 示 。 
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BBS 论坛 管理 系统 


EE a 


m 


| | Chancer Sabi | Fia Options | Merge Tabla Ciconia | Feclersted Table Opliong |- 


图 8-12 输入 数据 表 名 bbs main 
(3) 然后 再 切换 到 “Fields (内 容 )” 选 项 卡 中 ， 输 入 数据 域名 以 及 设置 数据 域 位 的 相关 
数据 ， 如 图 8-13 所 示 。 对 讨论 主题 做 一 个 全 面 的 分 析 ， 设 计 bbs main 的 字段 结构 如 表 8-3 
所 示 。 


表 8-3 讨论 主题 信息 表 bbs_main 


发 布 主 题 的 时 间 VARCHAR 20 


[Table [bhr mninl [hbs on inenlhnst]l 


wle fm B: 


: Mix |Broperbes | Eeka | eas | Tr | Dem | Depeneenges DL | 
Fald her Paii Typa Sia fradi Md Dim Tammar 


E a 
O ma 
E] ma 
Fs 
ii a 
[e| ea 
Ew 
"EI ha 
E u^" 


harass ibe oh locallinadi E ablic HL 
P: Takie i 


H 
H| 
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8-13 bbs main 数据 表 


"s PHP+ 


(4) 回复 主题 信息 表 bbs ref 字段 结构 采用 如 表 8-4 所 示 的 结构 。 设 计 后 的 数据 表 如 图 


8-14 HIZR o 


E A 
主题 编写 
回复 主题 编号 
回复 主题 人 的 姓名 
回复 主题 时 间 
回复 主题 内 容 
回复 人 性 别 
回复 人 的 个 人 主页 
回复 人 的 e-mail 


Databases 
- EJ Ilesalhoet 


3] memher on inen 
j| news on lc ast 
引 dou on locare 
Ne 
j|] voe on iacnihost 
T bba on localhost 


[El eee 


R 8-4 回复 主题 信息 表 bbs ref 


ESOL Eanager 2007 for Ny5glL bby on localhoxt. [bbs] [Table [bbs ref] [bbs 


Fidd Hren Fielel Type 
| E] bia moin, Er INTEGER 
LL bis Je P bea, ret Im INTFCER 

Generi . HI] bia mu name VARCHAR 

| E] bea, ret dime VARCHAR 

| D [e] Riresh EI] bien. ret, ennrtent TEXT 
SF compie A] pea, ret, me VARCHAR 
* Bia Grants on labis EH bea. rest uni VARCHAR 


E) bbs on kecali [es 


Fi bha rei nmad VARCHAR H 


gorainast bas an nealhagtTahlenduha ref i 


EFCHEF 
ARF be ZU 


| re 
aR HAR | = m Fiems 


I] bis ssi D INT 


图 8-14 bbs ref 数据 表 


(5) 最 后 设计 用 后 台 


登录 管理 的 admin 数据 表 ， 字 段 结构 采用 如 表 8-5 所 示 的 结构 。 设 


计 后 的 数据 表 如 图 8-15 MZR. 


BOX 
管理 员 信息 编号 
管理 员 账 号 


管理 员 密 码 


DA EX PEG EE 
便 后 面 登录 碍 询 使 用 。 


表 8-5 管理 员 管 理 信息 表 admin 


WP. Ea EHAK admin 里 输入 用 户 名 和 蜜 但 都 为 admin， 以 方 


tame 
11 
11 
A 
A 

n 


A 
A 
2) 


on locahlhost]] 


ipea" mec B 


Prge Deki: (pacer  TInggez Gaa | Dependergder 


Frei. Hoi 


-I2E-IE-YIE-IE-SIE-ZE-YE- 


梧 国 国 口 国 辐 国 国 
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BBS 论坛 管理 系统 


iba on locnihost [hbs] [Table = [ndmiml [bbs nm 


站 
SS “ |Bsperes | Eeka | waees | Triggers | Data | ts 
| (reine 


fei ek Type Sue raci Ho. Det 
Igi ie wepm € a E- 
VARCHAR 3 ü 
vaEcHAS 30 站 


8-15 后 台 管 理 admin 数据 表 


822 定义 bbs 站 点 


在 Dreamweaver CS 5.5 中 创建 一 个 “论坛 管理 系统 ”网 站 站 点 bbs， 由 于 这 是 PHP 数据 
库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 8-6 所 示 。 


站 点 名 称 bbs 
本 机 根 目录 CAApacheWtdocsWbbs 
测试 服务 器 CAApacheMtdocsV 
网 站 测试 地 址 http://localhost/bbs/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All UsersVApplication DataMySQLMMySQL Server 5.5\data\bbs 
管理 账号 / 密码 root / admin 
数据 库 名 称 bbs 


创建 bbs 站 点 具体 操作 步骤 如 下 。 
(1) 首先 在 CAApacheWtdocs 路 径 下 建立 bbs 文件 夹 ， 如 图 8-16 所 示 ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 


| xo damn X00 bR IAD HERO 
| O-* Arne OIRR DM 


ESI TETE e LII 
= 三 = x^ mH LC M 
TENTE TEXT YER Ski- A:S 

Sa età XE ul 
"i Es 名 这 个 主导 ug TE ?0ii-T-98 15:58 
ng URERTDE | THs Hni-T-T $$ 04 
p) REETTERMX ERA 2011-1-8 0:00 


[$] ea ao nt d " TE fült-b-15 8:41 
Tah "P TR zn1-T-4 9/35 
D SSXRE anum XER füii-1-3 18 3 


53 Hare mtt TEE 2011-76-30 15:30 
MA. PE THE £M1-T-11 18:48 

x Een XPG TrA 1161 10.08 

1a xm. dr 113 15: Lf 
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(2) 运行 Dreamweaver CS $.3， 选 择 菜 单 栏 中 的 “站 
上 护 ” 一 “管理 站 点 ”命令 ， 打 开 “ 管 理 站 点 ”对 话 框 ， 如 
图 8-17 所 示 。 

(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 
经 定义 的 站 点 。 单 击 右边 的 “新 建 ” 按 钮 ， 打 开 “ 站 点 设 
置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ”:， bbs. 

“本 地 站 点 文件 来” C:\Apache\htdocs\bbs\。 

如 图 8-18 所 示 。 


站 点 设置 对 和 象 bbs 


图 8-17 “管理 站 点 ”对 话 框 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweayver 
站 点 通常 包含 两 个 部 分 ; 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
来， 以 及 可 在 其 中 将 相同 文件 发 布 到 web 上 的 服务 器 上 的 远程 文件 夹 。 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 来 和 名 称 。 
站 点 名 称 ， 
本 地 站 点 次 件 夹 ; | Capache\htdocs\bbs' e 


K|8-18 Æ bbs 站 点 


(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 菠 |， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 8-19 所 示 的 参数 设置 。 

“IRI REER”: bbs. 

“连接 方法 ” 本地/ 网络。 

"mm ": C:\Apache\htdocs\。 

“Web URL”: http:// localhost/ bbs/. 


站 点 设置 对 和 象 bbs 


Ragam [bs | 
REDIR: 
IRS SRIF: | CA pachelhtdocs lg 


图 8-19 设置 “基本 ”选项 卡 


管理 系统 


(5) 设置 后 再 单 击 “高 级 ”选项 不， 打开 “高 级 ”服务 器 设置 对 话 框 。 单 击 “ 维 护 同步 
信息 ” 复 选 按钮 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 8-20 所 示 。 


站 点 设置 对 得 bbs 


版 本 控制 
> 高 级 设置 


维护 同步 信息 
O 保存 时 自动 将 净 件 上 传 到 服务 器 
O 自用 文件 取出 功能 

[VI 打开 文件 之 前 取出 


职 出 名 称 ; 
电子 邮件 地 址 ; 


测试 服务 器 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 
服务 器 模型 :| PHP MySQL E 


8-0 设置 “高 级 ”选项 卡 


(6) 单 击 “ 人 保存” 按钮， 返回“ 服务 器 ”设置 对 话 框 ， 再 单 击 选 择 “ 测 试 ” 复 选 按钮 ， 
如 图 8-21 所 示 。 
站 点 设置 对 犁 bbs 


您 将 在 此 位 置 选择 举 载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
Internet 服务 提供 商 (ISP) 或 web 管理 员 。 


注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步骤 。 如 果 要 连接 到 Web 并 发 
布 页 面 ， 您 只 需 定 以 一 个 远程 服务 器 即 可 。 


| 远程 “测试 | 


8-21 设置 “服务 器 ”参数 
单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 


才 所 设置 的 站 点 bbs。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 束 完成 了 
Dreamweaver CS 5.5 测试 论坛 管理 系统 网 页 的 网 站 环境 设置 。 


BOSE 设置 数据 库 连 接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 BBS 论坛 管理 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 


PHP 


与 数据 库 的 连接 设置 如 下 。 


(1) 将 光盘 中 设计 的 本 章 文件 复制 到 站 点 文件 夹 下 ， 打 开 BBS 论坛 首页 index.php, 
如 图 8-22 所 示 。 
DW | 器 "| 四 ”| O cue (Spe) | 


文件 (7) 编辑 (E) 查看 (WV) 插入 (I) EAM 格式 (0) 命令 ([C) 站 点 (5) 窗口 ( 吉 ARH) 


C:\Apache\htdocs\bbs\indexz. 


ü GÈ C n it: EHES /fC |; SMS htdocs/bbs/index. php EEGUNELRAMASE: 
koai j 1. 请 为 该 净 件 创建 一 个 站 点 。 
A v 2. 选择 一 种 立 档 类 型 。 
3. 设置 站 点 的 测试 服务 器 。 
4. ENS G) 按钮 并 选择 记 


”PHP 论坛 管理 系统 ;下 


10096 (338) = 


目前 没有 发 表 任 何 主题 
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5 admin login. php 
PD bbs add. php 
€ - 一 一 一 一 = - -一 = T bbs reply.php 
body? (table? tr? <td> <table> Ctr? (td? [Ct able?) (RI Q 100$ 896 x 431v 1 K / 1 fh Unicode (UTF-8) E content. php 
$ — : -o del reply.php 
zz 80! whoo |s ~| BAT) HFFA) Zi T) del title php 
can 3C) [i 间距 人 G) 0 | 边框 (8) EE 


^5) upd title.php 
3 ovg gs & C | | 
Ta (3 日 期 : 2011-8-5 12:07 


8-22 ”打开 论坛 首页 


(20 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 人 命令， 打开“ 数据库” 面板 。 在 “ 数 
据 库 ”面板 ， 单 击 选择 “+” 按 钮 ， 并 在 EE bale ^MySQL 连接 ”命令 ， 如 图 8-23 
所 示 。 


TIE 用 动 寿 数 据 : 
1 ATUS TFI Hh Ee 

2, 选择 一 种 立 档 闫 型 。 

3. NEED GB iie. 

4. Sii Em + HURE. 


图 8-23 选择 “MySQL 连接 ”命令 


(3) 在 弹出 的 “MySQL 连接 ”对 话 杠 中， 输入 “连接 名 称 ” 为 bbs,“MySQL 服务 器 ” 
名 为 localhost, “HPZ” X root， 密 人 码 为 admin。 选 择 所 要 建立 连接 的 数据 库 名 称 ， 可 以 单 
击 “ 选 取 ” 按 钮 ， 浏览 MySQL 服务 器 上 的 所 有 数据 库 ， 如 图 8-24a 所 示 。 选 择 刚 建立 的 范 
例 数 据 库 bbs， 具 体 的 设置 内 容 如 图 8-24b 所 示 。 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


连接 名 称 : 
MySQL 服务 器 : 
用 户 名 : 

密码 : 

数据 库 : 


bbs 


localhost 


root 


WEEEK 


bbs 


book 
db_shop 
gbook 


00 
information schema 


news 
performance schemaold 
phpweb 


8-4 设置 MySQL 连接 参数 
(4) 单 击 “ 测 试 ” 按 钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 果 正 确 ， 则 会 出 一 
个 消息 框 ， 如 图 8-25 所 示 ， 这 表示 数据 库 连接 设置 成 功 。 
单 击 “确定 ”按钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 和 面板 中 则 显示 绑 定 过 来 的 数据 库 ， 
如 图 8-26 所 示 。 


数据 库 | 绑 定 | 服务 器 行为 | 二 


*so— TEW. PE [e] 


NySQL 连接 


(g bbs 

日 “七 ”脚本 编制 
E BB admin 

| 0B9 ID Gnt 11 必需 的 ) 

j j MÀ Ta password (varchar 20 必需 的 

| | ZN username (varchar 20 必需 的 

I m-Bg bbs main 

: m-Bg bbs ref 

s WB 

mae Tace 


连接 名 称 : 
MySQL 服 等 器: 
用 户 名 : à) 成 功 包 了 连接 脚本 。 

TH: 

数据 库 : 


Dreamweaver 


确定 


< lll | > 


8-26” 绑 定 的 数据 库 


图 8-25 设置 成 功 


BBS 论坛 常理 系统 主页 面 设计 


在 Dreamweaver 中 定义 站 点 ， 建 立 数据 库 连 接 后 ， 就 可 以 进入 PHP 网 页 页 面 的 设计 阶 
段 。 首 先 制作 最 重要 的 首页 index.php. index.php 页 面 主要 显示 所 有 的 讨论 主题 和 最 新 回复 


的 一 些 信息 。 


UL BBS 论坛 管理 系统 主页 面 


BBS 论坛 管理 系统 的 主页 面 index.php 显示 所 有 的 讨论 主题 、 每 个 主题 的 点 击 数 、 回 复 


PHP-*MvySQL*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


AANEEN, 访问 者 可 以 单 击 要 阅读 的 标题 链接 至 详细 内 容 ， 管 理 员 单 击 “ 管 
图 标 进 入 管理 页 面 。 系 统 主页 面 mdex.php 的 静态 页 面 设计 如 图 8-27 所 示 。 


A 论坛 之 家 一 Nicroso ft Internet Explorer B) 
" 


Tr aE 查看 (WV) Rwa 工具 (TI) $Bh00 

QAE- OQ-.i[9imtf» mk xiex O6 2-354 

地 址 部 ) Æ] http: //127.0. 0. 1/bbs/ Bi Ra v E Ea 链接 Q Sna E 
- S 


: PHP 论 坛 管理 系统 元 
] 


BU. Qo ee e RR s : | 
查询 主题 : "olli. s 多 发 表 话题 | em 
作者 | BE | SR | HR xewa 


目前 没有 可 主题 
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8-27 BBS 论坛 管理 系统 主页 面 静态 设计 效果 


许 细 的 操作 步骤 如 下 。 

G) 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 由 按钮 ， 在 弹出 的 菜单 中 选择 “ 记 
录 集 (查询 )” 命 令 ， 在 弹出 的 对 话 框 中 进行 如 下 设置 。 

1) 在 “名 称 ” 文 本 框 中 输入 rs bbs 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 和 象 bbs- 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 和 象 为 bbs_main。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

完成 的 设置 情况 如 图 8-28 所 示 。 


Eee 


8-28 ”设置 “记录 和 集 ” 对 话 框 


二 ;二 二 也 BBS 论坛 管理 系统 


(2) 再 单 击 “ 高 级 ”按钮 ， 进 入 记录 集 高 级 设 定 的 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 
的 SQL 语法 ， 如 图 8-29 Wr. 


01. SELECT 
02. "bbs Main.bbs ID, 
03. bbs Main.bbs Time, bbs Main.bbs Hits 
04. ^bbs Main.bbs Title, bbs Main.bbs url, 
bbs Main.bbs email, bbs Main.bbs sex, 
bbs Main.bbs Face, bbs Main.bbs Content, 
05. bbs Main.bbs Name,COUNT(bbs Ref.bbs Main ID) AS ReturnNum, 
06. MAX(bbs Ref.bbs ref Time) AS LatesTime 
07. FROM 
08. bbs Main LEFT OUTER JOIN bbs Ref ON 
09. bbs Main.bbs ID-bbs Ref.bbs Main ID 
10. GROUP BY bbs Main.bbs ID 


. bbs| | 


: SELECT bbs Main. bbs ID, bbs Main.bbs Time, bbs Main. bbs Hits, 
bbs Main. bbs Title, bbs Main. bbs url, 
bbs Main. bbs email, bbs Main. bbs sex, 
bbs Main. bbs Face, bbs Main. bbs Content, bbs Main. bbs Name, COUNT 
(bbs Ref.bbs Main ID) AS ReturnHum, MAX(bbs Ref.bbs ref Time) AS 


表格 添加 到 SQL: 


到 视图 
d. ”预存 过 程 


WHERE 


ORDER BY 


图 8-29 改写 SQL 语句 


程序 说 明 : 

第 一 条 bbs ref 数据 表 中 的 记录 可 以 通过 bbs main ID 字段 关联 到 bbs main. 数据 表 中 的 
bbs ID 字段 。 因 为 bbs ref 数据 表 中 对 应 的 数据 可 能 不 存在 ，bbs_main 数据 表 并 非 一 定 有 对 应 回 
复 的 话题 。 所 以 LEFT JOIN 将 接合 关系 中 的 两 个 数据 表 分 成 左右 两 个 数据 表 ， 其 中 左边 数据 表 
在 经 过 接合 后 ， 不 管 右边 数据 表 是 否 存 在 ， 仍 然 会 将 资料 全 部 列 出 。 简 单 的 说 ， 怠 是 不 管 讨 论 
主题 bbs main 是 否 有 任何 的 回复 bbs ref, fEH] LEFT JOIN 可 以 将 数据 表 bbs. main 中 的 所 有 讨 
论 主 题 都 显示 出 来 。 

另外 ，GROUP BY 语句 是 针对 bbs main 数据 表 中 的 bbs ID 字段 ， 第 2 一 6 行 的 意思 是 
取出 bbs_main 数据 表 中 的 特定 字段 内 容 。 同 时 将 bbs_ref 中 的 关联 字段 取出 ， 获 得 bbs_time 


PHP 


和 bbs ID 的 两 个 字段 内 容 。bbs_ref time 字段 取 所 有 记录 当中 时 间 最 新 回复 的 那 一 条 用 来 显 
示 。 而 bbs_ID 字段 则 用 COUNT 计算 有 多 少 人 回复 的 数目 。 

(3) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 index.php 网 页 中 的 适当 位 置 ， 如 图 8-30 
所 示 。 


Dw | eH -|[98 — Oc [S] ES 
Tr ”编辑 (FE) 查看 (Y) 插入 (I) EM) EAO 命令 (C) 站 点 (3) 窗口 人 ARH 
C:\Apache\htdocs\bbs\indez. php 


bbs. php 
fi TRB] p? FI ANNEES] A OLERE, C mE: 
j GD C qiii: £ile:///C|/Apache/htdocs/bbs/index. php 


CERTES SN 


op 


目前 没有 用 表 寿 何 主题 
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| | 本 地 视图 
< T 
ee — | -一 -一 - — N « 
body? <table> tr? (td? <table> Ctr? Kt] R] Qj 100€ — .|783 x 401v 88 K / 2 $9 Unicode (UTF-8) - R] RIG | o9 这 Sg ul Er] 
无 v BI iiie dI o | 
QO 目标 (6) 


gr ex KERU v maion sameo r] 页 面 属性 
— oj £BO 高 标题 E) O 


文件 活动 已 完成 。 


8-30 ”字段 插入 全 index.php 


(4) 插入 字段 后 ， EM UC TRANI AI 


像素 ， 如 图 8-31 所 示 。 “确定 ”按钮 ， E ARUM. 

C5) 插入 “图 像 占 位 符 ” 之 后 ， 选 中 “网 像 占 位 符 ”， 单 击 “ 属 性 ”面板 中 的 “ 源 文 
件 ” 文 本 框 后 面 的 “浏览 文件 ”按钮 呈 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选择 
“数据 源 ” 单 选 按钮 ， 然 后 在 “ 域 ” 列 表 杠 中， 选择 “记录 集 (rs_bbs)” 选 项 中 的 bbs Face 
字段 ， 如 图 8-32 所 示 。 


选择 文件 名 自 : 〇 ) 文件 系统 站 点 根 目录 
人 @) 数据 源 站 点 和 服务 器 


域 : B 记录 集 rs bbs) 


8B | 
as 


bbs Content 
bb oe e 
PP) 


E EM 


| 
格式 : 无 
| 


URL: <?php echo $row rs bbs[ bbs_Face’ ]; ?> 


在 站 点 定义 中 更 改 默 认 的 链接 相对 于 
| 确定 || mud 


8-31 设置 “图 像 占 位 符 ” 对 话 框 8-32 ”选择 字段 


(QL*-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(6) 单 击 “ 确 定 ” 按 钮 ， 完 成 记录 集 的 绑 定 。 接 下 来 进行 显示 区 域 的 设置 ， 首 先 ， 选 取 
记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 8-33 所 示 。 


图 8-33 ”选择 要 显示 的 数据 表格 


C) 单 击 “服务 器 行为 ”面板 上 的 邮 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 显 示 区 域 ” 一 “如 
果 记 录 集 不 为 至 则 显示 区 域 ” 命 令 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 中 ， 
选择 “记录 和 集 ”下 拉 列 表 框 中 的 “rs_bbs” 选 项 ， 如 图 8-34a 所 示 。 单 击 “ 确 定 ”按钮 回 到 
编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 “如 果 有 下 列 情况 ， 即 显示 ”的 灰 
色 卷 标 ， 这 表示 已 经 完成 设置 ， 如 图 8-34b Hrs. 


MA IK SEA 29 TIER 


Dw | 设 i 器 ”| OG cue [ep] mE 
THT 编辑 (FEF) 查看 (Y) 插入 (I) 修改 (OD 格式 (0) 命令 (5C) 站 点 (5) ”窗口 (由 帮助 0D 

indez. php* X 
Ut bbs. php 


记录 集 Cs_bbs) 

如 果 记 录 集 不 泊 空 则 显示 (rs bbs) 
动态 尾 性 【img. sre, $row rs bbsL... 
动态 属性 (a href, $row rs bbs['... 
动态 次 本 (rs bbs bbs Title) 
mh (rs bbs. bbs Hame) 
ERAS (rs bbs ReturnNum) 
ERU (rs bbs LatesTime) 
动态 女 本 (rs bbs bbs Hits) 

动态 文本 (rs bbs. bbs Time) 


ze. 


NE: a 
| "s. 
| {rs_bbs. bbs_Title} 


ale 可 ai 可 
783 x 401v T1 K / 2 秒 Unicode (UTF-8) - EI | Lya B | F] 
^ 


BED E-G Coton 
a- images 
B css ma) a a EEL) | | E | E B so. | 
mmt... 列表 项 目 7 admin. php 11KB lv 
u J| > 


@ BM: 2011-6-5 12:07 (HÆ 


图 8-34 ”完成 显示 设置 
(8) 选择 没有 发 布 主题 数据 时 要 显示 的 文字 “目前 没有 发 表 任 何 主题 ” 根据 前 面 的 操 
作 方 法 ， 将 区 域 设 定 成 “如 果 记 录 集 为 衬 则 显示 区 域 ” 如 图 8-35a. b Br. 


PHP 


MI ok EO E M ET 


Mirz bbz 


Dw [aum | a 0 su [ICM 
| dadas. Mt X Ci Vache hil go Es e a mo ' 

[1 tn rip 
MAR TT] k ET -MME Mog GERI [vio C gm uus 
EC ero BAME HT Li hp esha bA dura! 


& PHP 论 坛 管理 系统 | 


ETE 
Li AS 

rdh cab Cur? cub Calice? [k]C)Q 105 Ta He TI K/ T Micoa T^ Uh Sje etr ag] 了 
gu i | 


[irm] E | ETE (- 97 iz m | 
ET mum x » WHO | 


Has es 


E 
—— j BM aneen E 
b) 


K|8-35 ”选择 没有 数据 时 的 显示 


C9) 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 设置 ， 单 击 index.php 页 面 中 要 重复 的 记录 
列 ， 如 图 8-36 所 示 。 


irs bbs.bbs Title] 


EY 
RN e ELS ED Sm... 


图 8-36 ”选择 要 重复 显示 的 记录 列 


(100 单 击 “应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 列 
表 中 ， 选 择 “ 重 复 区 域 ” 命 令 ， 在 打开 的 “重复 区 域 ” 对 话 杠 中， 设置 显示 的 记录 数 为 20， 
如 图 8-37 所 示 。 


(wx 
. © 20 | 记录 
O 所 有 记录 


帮助 


图 8-37 ”选择 一 次 可 以 显示 的 记录 数 


(11) 单 击 “ 人 确定” 按钮 ， 回 到 编辑 页 面 ， 会 及 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 
了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(12) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 当 记录 集 
超过 一 页 ， 束 必须 要 有 [上 一 页 ]、[ 下 一 页 ] 等 按钮 或 文 
学 ， 让 访问 者 可 以 实现 翻 页 的 功能 ， 这 就 是 “记录 集 导 
航 条 ”的 功能 。“ 记录 集 叶 航 条 ”按钮 位 于 “插入 ” 工 
具 栏 的 “数据 ”中 ， 因 此 将 “插入 ”工具 栏 由 “常用 ” 
切换 成 “数据 ”类 型 ， 单 击 “ 记 录 集 导航 条 ”|[ 加 工具 按 
钮 ， 如 图 8-38 所 示 。 

(13) 在 打开 的 “记录 集 导 航 条 ”对 话 框 中 ， 选 取 
要 导航 条 的 记录 集 以 及 导航 条 的 显示 方式 “文本 ”， 如 
图 8-39a 所 示 ， 然 后 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 
会 及 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 图 8-39b 所 示 。 


ERA: E ~) 
显示 方式 : @ yë 
O mg 


TENO Wam 3e 0 MAN PR SAD Ar 


el ee Fil 


HERRHEGRERDEN 


eceabe e RIEN EL ran 
cw] Hm x «|. mx -< BI PBiuirsmm O 
Hr O e| BE [dens faeeryPlrsng en bend: ut Eme 
| Xam] wemecr 
| semp 


ESL 
E 


8-39 


dri tbs. bha Wasal [e abha Haturua] [ri pbs. Latestimal ies, Hs Pba Hits] [ri bha. bha Tisal 


添加 “记录 集 导 航 条 ” 


数据 v 
(A Spy 重复 项 
EL spy 重复 列表 
(Q ERR 

f RU 

f) mss 
dj- Ems 
diosRRSKA 
ii. 显示 记录 计数 
C EHEAR 
597 插入 记录 v 


8-38 选择 “记录 集 导航 条 ” 


Dw | m | E Qaw | 


GREG] Gt) WU Www 17 
"s E C j a FC TE , EIE 


ERE eal O R 
mN.XWN-—TRETm rrt) 
MEME tr ttr) 
KUCFAN-TNET krii af 
k | 


vO El T&K DOM Wnicoda TAB | 00 10 


(14) 在 “讨论 主题 ”上 加 入 “ 转 到 详细 页 面 ”的 设置 ， 用 来 显示 特定 主题 的 详细 内 容 


及 相关 的 回复 。 选 取 编 辑 页 面 中 的 rs_bbs.bbs_Title ^^ Ec, 
如 图 8-40 所 示 。 

(150 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 
击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 选 
择 用 来 显示 详细 记录 信息 的 页 面 contentphp， 设 置 如 图 


ADRESSES HERI 


8-40 ”选择 字段 


PHP-* 


8-41 Brzn. 


选择 文件 名 自 : GO 文件 系统 METI EES 


O 数据 源 站 点 和 服务 器 
查找 范围 0): C bbs | O 2 ega 


ce  mmserverScripts bcd admin login. ph "9 del title.php 
Ce notes "7$ bbs add. php 中; index.php 
([CjConnecti ons e] bbs_reply. php ‘upd title.php 
Dineees - FE 

mdb "5 del ref. php 

"9 admin. php Rc del reply.php 


Abt): content. php 
TH (T): | 所 有 文件 o) 


VRL: content. php 
相对 于 : | PE v | index. php 
在 站 点 定 尺 中 更 改 默 认 的 链接 相对 于 


图 8-41 选择 链接 文件 


(16) 童 击 “参数 ” 投 钮 ， 议 置 超级 链接 要 附 市 的 URL 参数 的 名 称 与 值 ， 如 几 8-42a 所 
示 。 将 参数 名 称 命名 为 bbs id. (EU ELBITIES] pe Padi ART 8-42b 中 车 标 所 指 回 的 图 标 。 


[ug ERR es bts) 


bbz Time 
bbs Hits 
bbs Title 
bbs url 
bbs semail 
: bbs sex 
j bbs Face 
: bbs Content 


: 45 bbs Hame 
T.-— 


"php echo $row rs bbs[... | z 


tex 
ERU T 


图 8-42 “参数 ”和 “动态 数据 ”对 话 框 


(17) 单 击 “ 确 定 ” 按 钮 完成 “ 转 到 详细 页 面 ”的 设置 ， 在 index.php 页 面 中 有 两 个 链接 
图 示 “ 管 理 ” 与 “发 表 话 题 "”， 必 须 设 定 其 链接 网 页 ， 如 表 8-7 所 示 。 


表 8-7 按钮 链接 的 页 面 表 


按钮 名 称 链接 页 面 
管理 admin_login.php 


发 表 话 题 bbs_add.php 
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BBS 论坛 管理 系统 


ceno 搜索 主题 功能 制作 


在 index.php 这 个 页 面 上 加 入 搜索 的 功能 ， 访 页 面 上 的 功能 设计 如 图 8-43 所 示 。 


:| ü A 


8-43 ”搜索 主题 设计 


制作 步骤 如 下 。 
(1) 将 查询 主题 的 文本 域 命名 为 keyword。 设 置 如 图 8-44 Pr. 
属性 
立 本 域 ERPREE 0) 类 型 mE) Omm OTEP) S stylei8 
RévHEOS | WED | 多 
BEI 
O RE t) 


8-44 ”设置 keyword 文本 域名 


(2) 将 之 前 建立 的 记录 集 rs bbs 做 一 些 更 改 ， 打 开 记 录 集 ， 并 进入 “高 级 ”i 
在 原 有 的 SQL 语句 中 GROUP BY bbs_Main.bbs_ID 前 面 ， 加 入 一 段 查询 功能 的 语法 : 


where bbs, Title like '%".$keyword." %' 


SQL 语句 将 变 成 如 图 8-45 所 示 。 


M 


LatesTim 
FROM bbs re in LEFT OUTER JOIN bbs_Ref ON 
bes Mai iy .bbs ID-bbs Re £. bbs Main ID 

ra bbs THAI od "€, 


bs Title like ^X .$kev i j 
GEDUE 5 bbs Main. bbs ID 


数据 库 项 : 表格 添加 到 SQL: 
= 
d. Next 


WHERE 


ORDER BY 


8-45 修改 SQL 语句 


(3) 再 切换 到 代码 设计 窗口 。 在 rs_bbs 记录 和 集 绑 定 的 代码 中 加 入 代码 : 


$keyword-$ POST[keyword]; /定义 keyword 为 表单 中 "keyword" 的 请 求 变量 


设 定 对 话 框 。 


e 


PHP 


如 图 6-46 所 示 ， 完成 设置 。 


Dw | 
mo ado xc Wc (xa KAM ic) i) wacm | 


Te require . IT Cernections/tbs, php'bs * 
Ho 1 1) 

站 二 让 iti i y "EMT keyword IH ET ES TTEE TES irz tbr] 
if qUrUTUETET[E UIT IY i HX T—U irs bbs) 

Éunrrion GechübTalusSrringi(iézheValue, $zheType, $rheDefinedYVmlue a "^, MKETASUL-—OAINIET iz bbr) 
(zheKorcbefinedYVa]ue a "") BRxXNG—E eb 

i muracngpEIEm futb) 

if (PHP VERSION < ó} i EHZ ir: bhi 


" i " = RENE (ag ero, fros ru the] 
$theValue a get magic gotes gpc() ? stripslashes(stheValue] : stheValue: Ten "ire Mat 


' BREITE (ra ba hs Tia 


itheValue a functian exisrs|^mysgl real escape string") ? mysql real escape string| 
PthaValus] : mysql escape string[rtnevalue]: 


图 
ij 
+e "n 
L " 
M. 
= 


sitéb (stergpéb [ m 
came "EEREUI 
Pthsvalus = (rtheValus 1e 7") f "'5 . ptheYalue . 77"; "i AUERTT 
break; rs 
case “longi z 
eame “inti j TTE 
iunevalus = (itheValue Be ^"| 7 intval[stheVvalue) ; "NULL": E iie 
break i ga 
Eme “double”: Mos 
pHhaTalue = qErtheValue Be =") 3 dosbleval(ftheValus) p "MULL"; ER A 
3 is lept. i 
| Ebr add php 
TA K / £7. Unicode WA - grecum 
o £ahiant. php 
TD dal raplr phe 
FaoysardcE MOST [yard]; dr te Um k CHUERR jo] titia phe 
a rs r 
par: e ayar ee 


i£ functi exiiti wis | 
Puneti em M i da ihaTypa, fakalainadValwa 2 "UU, TadaNatBafimadValus i api titie phy 


IE PE NEESI 5 8) | 


He 


[« anaa E 


8-46 ”加 入 代码 


(4) 以 上 的 设置 完成 后 ， 系 统 主页 面 index.php 就 有 查询 功能 了 ， 可 以 按 下 (F12) 键 至 
S 测试 一 下 是 耕 能 正确 地 查询 并 显示 。index.php 页 面 会 显示 所 有 网 站 中 的 讨论 主题 ， 
wee 8-47 所 示 。 


us 访问 者 页 面 的 设计 


F 论坛 之 家 一 了 icrosoft Internet Explorer 

THFT AHE 查看 WV) REA 工具 (IT) 帮助 0) 

QmB-O-|9i(dt Psk kiez 6 2-54 

地 址 0) |] http: //127.0. 0. 1/bbs/?keyword-test&Subni t-XESXOFNASNEGNAFNA2 二 输入 关键 词 搜索 €-Ejses sm Q snust g 


we 


发 布 时 间 


ERISA R RANER 


Copyright @ 2011 www. hbculture. com Inc. All rights reserved. 论坛 之 家 


图 8-47 主页 面 讨论 主题 的 浏览 效果 


e 


耸 坛 访 问 者 使 用 的 页 和 面 有 讨论 主题 内 容 页 面 contentphp 和 回复 讨论 页 面 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


EOM T ON ETETETT Ea BBSielz EER 


bbs reply.phpe F TLLA T ARX PAA Va AIEE e 
s 讨论 主题 内 容 页 面 


讨论 主题 内 容 页 面 content.php 是 实现 讨论 主题 的 详细 内 容 页 面 。 这 个 页 面 会 显示 讨论 主 
题 的 详细 内 容 与 所 有 回复 者 的 回复 内 容 ， 其 静态 页 面 设计 如 图 8-48 所 示 。 


É 论坛 之 家 — Nicroso ft Internet Explorer DAR) 
THF AmE SA0 收藏 必 ) IAM EH) [7 
QmB- O-[9(gt6 Pss wx 6 2-32 


地 址 0) E http: //12T. 0. 0. 1/bbs/content. php 


^ 


G pz © 主页 


D G 电子 邮件 © 主页 
目前 役 有 回复 


Copyright @ 2011 www hbculture.com Inc.All rights reserved. 论坛 之 家 


8-48 讨论 主题 内 容 页 面 设计 效果 


详细 的 操作 步骤 如 下 。 

(1) 在 content.php 这 个 页 面 中 ， 要 同时 显示 讨论 主题 与 回复 主题 的 内 容 ， 因 此 需要 把 两 
个 记录 集 进行 合并 ， 一 次 取得 这 两 个 数据 表 中 的 所 有 字段 ， 根 据 主题 页 面 传送 过 来 的 URL 
参数 bbs ID 进行 筛选 。 

(2) 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 凶 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 集 〈 得 询 )” 人 命令， 在 打开 的 “记录 集 ” 对 话 框 中 单 击 “ 高 级 ”按钮 ， 进 入 记录 集 高 级 
设 定 的 对 话 框 ， 将 现 有 的 SQL 语句 改 成 如 下 的 SQL 语句 ， 如 图 8-49 所 示 。 


01. SELECT 

02. bbs main.*,bbs ref.* 

03. FROM 

04. bbs main LEFT OUTER JOIN bbs ref ON bbs main.bbs ID- 
bbs ref.bbs main ID 

05 WHERE bbs main.bbs ID 2'"".Sbbs ID." 


"PHP 


名 称 : detail 


SQL: SELECT bbs main. *,bbs ref.* 
FROM bbs main LEFT OUTER JOIN bbs ref ON 
bbs main. bbs ID-bbs ref.bbs main ID 
WHERE bbs main.bbs ID -'".$bbs ID." | 


表格 
m x9 视图 
Gd. MPH 


ORDER BY 


8-49 改写 SQL 语句 


重点 说 明 : 同样 用 LEFT OUTER JOIN XJ bbs main 和 bbs ref 中 的 字段 ， 取 得 两 个 数 
据 表 中 的 相关 数据 。 并 且 用 WHERE 3&4], (pit bbs main 数据 表 中 的 bbs ID. 字段 值 等 于 
$bbs ID 变量 值 。 

(3) 上 图 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 首页 传递 过 来 的 的 参数 ， 因 此 在 议 
页 目 动 生 成 的 PHP 代码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 


$bbs ID-strval($ GET[bbs id']); 


(4) 在 设 定 记 录 集 绑 定 后 ， 先 把 记录 集 detail 中 的 字段 插入 到 页 面 上 ， 再 分 别 插入 两 个 
图 像 占 位 符 ， 两 个 图 像 占 位 符 分 别 绑 定 发 布 人 性 别 形象 bbs sex 字段 和 回复 人 性 别 形象 
bbs ref sex 字段 ， 其 结果 如 图 8-50 所 示 。 


ba phot 


rs php 


! 


-— 


i dnd a La LAs a adta e L'e a Aaoi da da bda Lu ba Aa Be Measte dd a da bale b adeta u Le e aedade 让 "eren 


m 


AWA 2 [details name] 


ERR : (dete bbe content) 


-— — 


ppc Ogurm 


E URAR: (detallebe nf content) 


FA t (details ral same) 


C7 qdehulhbs mf ne] 26 reap 6 cem 


umo M NU———M———————M—Á— 


| Th om Mi le T2 EJ 2 9€ bids WTA) 


——————— 


8-50 detail 中 的 字段 插入 
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学 ;二 现世 BBS 论坛 管理 系统 


(5) 单 击 选择 主题 表格 中 的 文字 “电子 邮件 ”， 然 后 单 击 “ 属 性 ”面板 中 “链接 ”文本 
框 后 面 的 “浏览 文件 ”按钮 加 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选择 “数据 源 ” 
单 选 按钮 ， 然 后 在 “ 域 ” 列 表 杠 中， 选择 “记录 集 (detail)” 中 的 bbs email 字段 ， 并 且 在 
URL 链接 前 面 加 上 mailto:， 如 图 8-51 所 示 。 


选择 文件 名 自 : OO 文件 系统 


域 : | 日 号 ”记录 集 (detail) 
4 bs ID 

— 42 bbs title 
47 bbs content 
47 bbs name 

— 47 bbs time 

| 47 bbs face 
4 bbs sex 
£ bbs email 
4; bbs url 
4 bbs hits 

i Ea Lim -s2- TI 

格式 : 无 

URL: Imailto: <?php echo $row detail[ bbs email 


在 站 点 定义 中 更 改 默 让 的 链接 相对 于 


图 8-51 设置 主题 栏 中 的 email 的 链接 


(6) 单 击 选择 主题 表格 中 的 文字 “主页 ”， 单 击 “ 属 性 ”面板 中 “链接 ”文本 框 后 面 的 
“浏览 文件 ”按钮 呈 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选择 “数据 源 ” 单 选 按钮 ， 
然后 在 “ 域 ” 列 表 杠 中， 选择 “记录 集 (detail)” 中 的 bbs_url 字段 ， 并 且 在 URL 链接 前 面 
加 上 http://， 如 图 8-52 所 示 。 


选择 文件 名 自 : 〇 文件 系统 
(5 数据 源 


M[m Gh dE (detail) 
bbs ID 

bbs title 

bbs content 
bbs name 

bbs time 

bbs face 

bbs sex 


bbs email 


y VES WX X WX WWW 


bbs hits 
lil 2.2- 


Tn 


格式 : 天 | vj 
URL: http://K?php echo $row detail['bbs url']| 


在 站 点 定 尺 中 更 改 默 让 的 链接 相对 于 


图 8-52 设置 主题 栏 中 的 url 链接 
CD 利用 第 5. 6 步 中 的 方法 ， 设 置 其 回复 人 的 “电子 邮件 ”和 “主页 ”的 链接 。 一 个 
是 “记录 集 (detail)” 中 的 bbs ref email 字段 ， 一 个 是 “记录 集 (detail)” 中 的 bbs ref url 
字段 ， 如 图 8-53 和 图 8-54 所 示 。 
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选择 文件 名 自 : ORI 
(o 数据 源 


bbs email 

bbs url 

bbs hits 

bbs main ID 
bbs ref ID 
bbs ref name 
bbs ref time 


bbs ref content 


bbs email 

bbs url 

bbs hits 

bbs main ID 
bbs ref ID 
bbs ref name 
bbs ref time 
bbs ref sex bbs ref content 
bbs ref url 


bbs ref email $£ bbs ref url 
Lle 2.£ oomoo 


NYY 
EX S NS NN NN 


bbs ref sex 


格式 : 无 v 格式 : 无 


VRL: mailto: <?php echo $row detail[' bbs ref e| URL: http: //K?php echo $row detail bbs ref u| 


在 站 点 定义 中 更 改 喷 认 的 链接 相对 于 在 站 点 定义 中 更 改 默认 的 链接 相对 于 


图 8-53 ”设置 回复 栏 中 的 email 的 链接 图 8-54 设置 回复 位 中 的 url 链接 


(8) 单 击 “ 确 定 ” 投 钮 ， 完 成 效 据 源 的 绑 定 设置 ， 在 content.php 页 面 中 有 两 个 链接 图 示 
“管理 ”与 “发 表 话题 ” 必须 设 定 其 链接 网 页 ， 如 表 8-8 HZR o 


表 8-8 按钮 与 链接 页 面 表 


按钮 名 称 链接 页 面 
管理 admin_login.php 
发 表 话 题 bbs_add.php 


(9) 选择 文字 “回复 主题 ” 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文 
件 ” 图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 content.php， 设 置 如 图 8-55 
所 示 。 


选择 文件 名 自 ; dre 让 点 根 目录 


查找 范围 0): C) ts y| o 2em 


B  mmServerScripts e] admin_login. php "6, del reply.php 
C notes bcd bbs add.php 全 del title.php 
[Comecti ons Robb s reply.php El index. php 


ID images "6, content.php yupd title.php 


(mdb [E] coten. txt iu 


ac admin. php "6, del ref.php 


XAM: [bbs reply php i 


HSE (T): AAR G+.*) 司 [n 
URL: [bb s_reply. php M 
相对 于 : 文档 v content. php 

在 站 点 定 尺 中 更 改 默 让 的 链接 相对 于 


图 8-55 ”选择 链接 文件 


第 8 章 ”CE 


C100 蛙 击 “参数 ”按钮 ， 设 置 超 级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 将 参数 名 称 命 
名 为 bbs_ID， 设 置 如 图 8-56a、b 所 示 。 


域 :| 日 GR d (detail) ^ © 


bbs_title ` 
bbs_content C 三 
bbs name 

bbs time 

bbs face 

bbs sex 

bbs email 

bbs url 

bbs hits 

Tle = ocem 


n S S S S ES 


格式 : 无 


HRID: <?php echo $row detail['bbs ID']| 


图 8-56 “动态 数据 ”对 话 框 


CD 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 设 定 ， 单 击 contentphp 页 面 中 要 重复 的 表 
格 ， 如 图 8-57 所 示 。 


回复 人 : {detailbbs_ref name] 回复 内 容 : {detailbbs_ref_content} 


EÒ {qetailbbs_ref time) 要 ”电子 邮件 © 主页 


图 8-57 选择 要 重复 的 表格 


(12) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 办 按钮 ， 在 弹出 的 菜单 
中 ， 选 择 “ 重 复 区 域 ” 合 令 ， 在 打开 “重复 区 域 ” 对 话 框 中 ， 设 置 显 示 的 记录 数 为 5 条 ， 如 
图 8-58 所 示 。 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 和 角 
出 现 了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 


ERE: (detail 
gm. © B | 记录 


O 所 有 记录 


图 8-58 ”选择 一 次 可 以 显示 的 记录 数 


(13) 搬入 “记录 集 导 航 条 ”功能 ， 单 击 到 工具 按钮 ， 在 打开 的 “记录 集 导 航 条 ”对 话 
框 中 ， 选 取 要 导航 条 的 记录 集 以 及 导航 条 的 显示 方式 ， 如 图 8-59a 所 示 ， 然 后 单 击 “ 确 定 ” 
按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 图 8-59b 所 示 。 


“记录 集 ” 下 拉 列 表 框 中 的 “detail” 选 项 ， 


记录 和 集 导 和 条 


taecheVhtdoczNbbteoathnt php Hx 


讨论 + n. [delia bhs. te 
o ———— 


Fa 
E EENE : {desuilbbs content) 


[| 
f PRA: (iabe name) 
i 


| F ma ox Darra 


回复 内 容 : feniailbbe_raf contani} 


FRSA, : (dril bka ref nasse] 


hd 
Oed). Ctable? Cte) CU (Cr able] [AQ 10€ — e BAT m 5229 TT K / 2 1€ Vniesds QITF-8) 


b) 
图 8-59 添加 “记录 集 导航 条 ” 


(140 选取 记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 8-60 所 示 。 


回复 人 : [detailbbs ref name) 回复 内 容 : {detailbbs_ref_content} 


UP {qetailbbs ref time) $7 EFA © 主页 


图 8-60 选择 要 显示 的 数据 表格 
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(150 单 击 “ 服 务 器 行为 ”面板 上 的 外 按钮 ， 在 弹出 的 菜单 中 选择 “显示 区 域 ” 一 “如 果 


记录 集 不 为 衬 则 显示 区 域 ” 命 令 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 中 ， 选 择 
如 图 8-61a 所 示 。 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 
面 ， 会 发 现 先 前 所 选取 要 显示 的 区 域 左 上 和 角 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 …” 的 灰色 卷 


标 ， 这 表示 已 经 完成 设置 ， 如 图 8-61b 所 示 。 


M Io SEP 29 Z7 BA Sio DR 


图 8-61 完成 设置 后 的 效果 


回复 人 : (detaillbbs ref name) 回复 内 容 : (detailbbs ref content] 


UJ (detalbbs rf time) S 电子 邮件 © 主页 


b) 
8-61 ”完成 设置 后 的 效果 〈 续 ) 


(16) 选择 没有 回复 数据 时 要 显示 的 文字 “目前 没有 回复 "， 根 据 前 和 面 的 步 桑 ， 将 下 面 区 
域 设 定 成 “如 果 记 录 集 为 空 则 显示 区 域 "” 如 图 8-62a、b Br. 
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回复 上 : 回复 内 容 : [detailhbs ref content] 
{detal bbs ref name} 


LJ (detalbbs rf time) 电子 邮件 © 主页 
AUS REG ELTE Bs. F 
H Bii Bl 


b) 


K|8-62 ”选择 没有 数据 时 的 显示 


8.42 设 置 点 击 次 数 


在 BBS 论坛 系统 主页 面 中 设置 了 文章 阅读 统计 功能 ， 当 访问 者 点 击 标题 进入 查看 内 容 
时 ， 阅 读 统 计数 目 束 要 增加 一 次 。 其 主要 的 方法 是 更 狐 数 据 表 bbs main 里 的 bbs_hits 字段 来 
实现 。 

详细 操作 步骤 如 下 。 

COD 实现 的 方法 很 徐 单 ， 打 开 contentphp 页 面 ， 在 代码 的 第 50 行 加 入 一 行 更 狐 的 SQL 
语句 : mysql query("UPDATE bbs main SET bbs hits = bbs hits + 1 WHERE bbs ID = 
" $Sbbs ID."'"); 

代 公 说 明 如 下 : 

01.UPDATE bbs_main IE Ýi bbs main 数据 表 
02.SET bbs_hits = bbs_hits + 1 /设置 bbs main 数据 表 中 的 bbs. hits 中 字段 自动 加 1 


"P PHP+ 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


03.WHERE bbs ID = "".$bbs ID." // bbs ID 的 值 等 于 $bbs_ID 变量 中 的 值 


(2) 加 入 的 代码 位 置 如 图 8-63 所 示 。 


= coa etu at does Ws eont ent. paps -0x 


) 
+. 
1 
e y $currentPage = 4 SERVER("M? SELF"); 
v £maxKovs detall = $; 
(pageNun d | ; 
w 1f (1s3et(6 CET['pogeMum detail']))) 4 
[i3 4 (pageNum derail = $ GET[ 'pegelun dezai11']; 
i ! 
[as] i $statthou detail] = $pegeMus detail * £maxRows detallz 
2 i4 Maia select. gp tabase bbs, 6b we M 
[3 4 ydereil = "SELECT tbs pain. *,bbs ref.* FROM bbs mein um OUTER 9m We; ref ON 
spa p — : "bbs zef.bbs báin, "y" VIERE bda main ane. ap Aa „Ebda. "ID. 
ir m Lim ail - mprintf[" LIMIT +d, X4^, $quety il, fè how de i, $maxKous detail); 
g ; tae il = aya " quecy(f query li ty (bbs) ot die rati ma MOM 
E 4 pa etail = mysql fetch AUN deta11); 
£ 
2 
i it ener rias ipd Mortgages proce ( 
= (totalPRows detail = $ GET[*totalRovs detail"): 
) eise ( 
as ¢all_ deras] -— .query(équery de epe 
£. ma * derail = mysql mum ee 11 detail)? 
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图 8-63 ”代码 加 入 的 位 置 


新 增 讨论 主题 页 面 bbs_add.php 的 功能 是 将 页 面 的 表单 数据 新 增 到 站 点 的 bbs main 数据 
表 中 ， 页 面 设 计 如 图 8-64 Br. 


T C: \Apache\ht docs\bbs\bbs_add. php - [galea 


|:oegdo*os$o9o9o8 
| 
_ 人 主页 


确定 提交 


rt- 
(R| Qj 100€  . T9898 x 591v 81 K / 2 f^ Unicode (UTF-8) — - 


图 8-64 ”新 增 讨 论 主题 页 面 效 来 


详细 操作 步骤 如 下 。 


(1) 在 bbs add.php 页 面 设计 中 ， 表 单 forml 中 文本 域 和 文本 区 域 设置 如 表 8-9 所 示 。 


学 ;主席 和 BBS 论坛 管理 系统 


这 里 要 注意 性 别 形 象 和 心情 的 单 选 近 钮 都 要 在 属性 面板 中 定义 其 值 。 


表 8-9 RË fomi 中 的 文本 域 和 文本 区 域 设 置 方法 表 


意义 文本 (区 ) 域 /按钮 名 称 方法 /类 型 e 
性 别 形象 单 选 按钮 

stunt ae 

阅读 次 数 初始 值 为 0 


(2) 在 bbs add.php 编辑 页 面 ， 单 击 “ 服 务 器 行为 ”面板 上 的 外 按钮 ， 在 弹出 的 菜单 
中 ， 选 择 “ 插 入 记录 ”命令 ， 在 “搬入 记录 ”的 对 话 框 设置 如 下 。 

1) 从 “连接 ”下 拉 列 表 框 中 选择 bbs 作为 数据 源 连 接 对 象 。 

2) 从 “插入 表格 ”下 拉 列 表 框 中 选择 bbs main 作为 使 用 的 数据 库 表 对 象 。 

3) 在 “插入 后 ， 转 到 ”文本 框 中 设置 记录 成 功 添加 到 表 bbs_main， 然 后 再 转 到 
index.php 网 页 。 

4) 在 “ 列 ” 的 列 选 对 话 框 中 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 bbs main 中 的 字段 一 
一 对 应 起 来 。 

设置 完成 后 该 对 话 框 如 图 8-65 所 示 。 


提 变 值 ， 自 : forml v| 
连接 : bbs v 
插入 表格 : (bbs_main v 


| bbs content' M, 'FORM.bbs content XERRBÍE' 304 
|' bbs name' M " FORM. bbs name' 获取 值 作为 CN 
, . , LI L , X* HD = a , [7 z ^ 
2 D FE A , , 


到 |: 


|’ bbs_ 
'bbs email' JA “FO 
|l'bbs url' M’ 


值 : |FORM. bbs tine E 
IRU M: 文本 ba | 
插入 后 ， 转 到 : index.php 


图 8-65 WE "i^i 


(30 选择 表单 执行 菜单 栏 上 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 
为 ”面板 中 的 国 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “检查 表 单 ” 命 令 ， 打 开 “ 检 查 表单 ”对 话 
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框 ， 设 置 “ 值 ”和 “可 接受 ”范围 。 如 文本 bbs_email“ 值 ”设置 为 “必需 的 ”，“ 可 接受 ” 
为 “电子 邮件 地 址 ” 如 图 8-66 所 示 。 


input “bbs name" (KJ 

input “bbs email" (REizEmail] 
input "bbs url" 

textarea "bbs content" [R] 


(8: 必需 的 


Tes O 性向 东西 O mee 
© 电子 邮件 地 址 O mM | | 到 | | 


8-66 “检查 表单 ”对 话 框 


(4) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 完 成 bbs add.php 页 面 插入 记录 的 设置 。 
(5) 按 下 《F12〉 键 至 浏览 如 测试 一 下 。 首 先 打 开 bbs add.php 页 面 再 填写 表单 ， 填 写 表 


单 资料 如 图 8-67 所 示 。 


db uini - Hicrosoft Internet Explorer 
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(6) 填写 资料 完成 以 后 ， 单 击 “ 确 定 提交 ”按钮 ， 将 此 资料 发 送 到 bbs main 数据 表 中 。 
页 面 将 返回 到 BBS 讨论 系统 主页 面 index.php， 如 图 8-68 所 示 ， 表 示 发 布 新 主题 成 功 。 


Dao oo 5 s * 


d tte Nicroszoft Internet Explorer 


xit) dm) 要 看 税收 本 IAT) Ehi 
Dar- OQ [ig fe JN TOR 6 Gri 
dT ET phg? 000 


kä 


回复 讨论 主题 页 面 bbs_reply php 的 设计 与 讨论 主题 内 容 页 面 的 制作 相似 ， 回 复 主题 是 将 
表单 中 填写 的 数据 插入 到 bbs. ret 数据 表 中 ， 页 面 设 计 效果 如 图 8-69 所 示 。 


与 论坛 之 家 Wicrosoft Internet. Explorer Mial” 
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图 8-69 ”回复 讨论 主题 页 面 设计 效果 


CD. 由 于 在 讨论 主题 内 容 页 面 contenLphp 中 ， 设 定 有 传递 参数 bbs ID 〈 主 题 编 号 ) 会 
传递 到 这 一 页 面 ， 因 此 必须 先 将 这 个 参数 绑 定 到 一 个 命名 为 bbs main ID 的 隐藏 域 中 。 在 页 
面 上 插入 以 下 隐藏 域 ， 并 命名 为 bbs main ID， 并 定义 其 值 为 


<?php echo $bbs main ID ?> 


如 图 8-70 所 示 。 
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尾 性 
IN ES iix: ih 
(BO) (Cris echo Soos mein D |A 


图 8-70 ”设置 隐藏 域 bbs_main_ID 的 值 
(20 Aag Me 按钮， 切换 到 代码 窗口 ， 将 如 下 的 代码 加 入 到 第 117: 


<?php 
$bbs_main_ID=strval($_GET['bbs_ID']); 
7» 


如 图 8-71 所 示 。 
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图 8-71 加 入 代码 
(3) 再 插入 一 个 隐藏 字段 bbs_ref_time， 绑 定 为 当时 的 时 间 。 


<?php 
date_default_timezone_set('Asia/Shanghai'); 
echo date(" Y-m-d"); 

po 


属性 面板 的 设置 如 图 8-72 所 示 。 


en 


区 E ei. h 
1B) phpdate default timezone, set rj 


图 8-72 设置 隐藏 区 域 值 


二 ;二 二 也 BBS 论坛 管理 系统 


(4) 在 bbs_replyphp 编辑 页 面 ， 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 中 的 
国 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 “插入 记录 ”命令 ， 在 “插入 记录 ”的 设 定 对 话 框 中 设 
置 如 下 。 

D 从 “连接 ”下 拉 列 表 框 中 选择 bbs 作为 数据 源 连 接 对 象 。 e 

2) 从 “插入 表格 ”下 拉 列 表 框 中 选择 bbs. ref 作为 使 用 的 数据 库 表 对 象 。 ja 

3) 在 “插入 后 ， 转 到 ”文本 框 中 设置 记录 成 功 添加 到 表 bbs_ref， 然 后 再 转 到 index.php —— 


网 页 。 
4) 在 “ 列 ” 列 选项 中 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 bbs ref 中 的 字段 一 一 对 


设置 完成 后 ， 访 对 话 框 如 图 8-73 所 示 。 
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iB: En bbs. nain ID 
RTH: | 整数 
插 人 后 ， 转 到 : index. php 


图 8-73 设置 “插入 记录 ”对 话 框 


(5) 选择 表单 执行 菜单 “窗口 ”一 “行为 ”命令 ,打开 “行为 ”和 面板 ， 单 击 “ 行 为 ” 面 
板 中 的 外 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表 单 ” 命 令 。 打 开 “ 检 查 表单 ”对 话 框 ， 设 置 
文本 域 的 “ 值 ” 为 “必需 的 ”，“ 可 接受 ”为 “任何 东西 "其 中 bbs ref email 字段 为 “电子 
邮件 地 址 ” 如 图 8-74 所 示 。 


input "bbs ref name” - Œ) 


iR) 
textarea “bbs ref content" (R) 


i: |] eme 


TES O frfkp O 数字 
© 电子 邮件 地 址 局 数字 人 | | 到 | | 


图 8-74 设置 “检查 表单 ”对 话 框 
(6) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 这 样 就 完成 了 bbs_reply.php 页 面 插 入 记录 
的 设计 。 
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C) 按 下 《F12〉 键 至 浏览 费 测试。 首先 打开 首页 面 ， 选 择 其 中 任 总 一 个 讨论 主题 ， 进 
入 content.php 页 面 ， 在 content.php 页 面 单 击 “ 回 复 主 题 ” 转 到 回复 讨论 主题 bbs_reply.php 
页 面 ， 在 bbs reply.php 页 面 填写 表单 ， 填 写 表 单 资 料 如 图 8-75 所 示 。 


THT Rw) FE R IR Waow 
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PHP 论 坛 管理 系统 : 


8-75 ”填写 表单 资料 


(8) 填写 资料 完成 以 后 ， 单 击 “ 确 定 提 交 ” 投 钮 ， 将 此 资料 发 送 到 bbs ref 数据 表 中 。 
页 面 将 返回 到 BBS 讨论 区 系统 内 容 页 面 index.php， 和 再 单 击 主题 后 可 以 看 到 回复 ， 如 图 8-76 
所 示 ， 表 示 回 复 主 题 成 功 。 


文件 各) 4o) FF BRO IR Whio 
gat- 0 9g PRE Uw&A O6 OC- LBE 
IRIE M) ME) http //127 0.0. t/bbs/esntent. php?bbs_ id:2 AATRE w grs W* Qut 


PHP 论 坛 管理 系统 “7 LES 
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8-76 回复 主题 成 功 


| Section. 


BBS 论坛 管理 系统 的 后 台 管 理 比 较 重 要 ， 访 问 者 在 回复 主题 时 间 复 一 些 非法 或 者 不 文明 
的 信息 时 ， 管 理 员 可 以 通过 后 从 对 非法 或 不 文明 的 信息 进行 删除 。 


AXE nasiss o ， 


由 于 管理 页 和 面 是 不 允许 网 站 访问 者 进入 的 ， 必 须 受到 权限 管理 ， 可 以 利用 省 理 员 账 号 和 
管理 密 但 来 判 列 是否 有 此 用 户 ， 设 计 如 网 8-77 所 示 。 


A CrzXAÀpacheXhtdoczXbbszXadmin login. php* 


S EN 


和 和 


[CERES 


SIT x 143w B EK / 1 fÜ Unicode (UTF-8) .: 


8-77 “BBS 后 台 版 主 登录 页 面 ”设计 


其 详细 操作 步骤 如 下 。 

(OD 打开 后 台 版 主 登录 页 面 admin_login.php， 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行 
A" 面板 上 的 处 按钮， 在 弹出 的 菜单 中 选择 “用 户 身 份 验证 /登录 用 户 ” 的 命令 ， 在 打开 
“登录 用 户 ” 对 话 框 中 ， 设 置 为 如 果 不 成 功 将 返回 BBS 论坛 系统 主页 面 index.php， 如 果 成 功 
将 转向 后 台 版 主管 理 页 面 admin.php， 设 置 如 图 8-78 所 示 。 


从 表单 获取 输入 : forml 
用 户 名 字段 : username 
密码 字段 : password 
使 用 连接 验证 : bbs 
表格 : | admin 
用 户 名 列 : username 
密码 列 : password 


如 果 登 录 成 功 ， 转 到 : admin. php 
器” 转 到 前 一 个 URL( 如 果 它 存在 ) 
dn ERE , $]: index.php | 
基于 以 下 项 限制 访问 : 9 Reque 

〇 OC 用 户 名 、 密 码 和 访问 级 别 

苹 职 级 别 自 : ID 


8-78 设置 “登录 用 户 ” 对 话 杠 
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(2) 选择 表单 ， 执 行 采 单 “ 窗 口 ” 一 “行为 ”命令 ， 打 开 “ 行 为 ”和 面板， 单 击 “行为 ” 
面板 中 的 外 | 按钮， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 设 
置 username 和 password 文本 域 的 “ 值 ” 都 为 “必需 的 ”，“ 可 接受 ”为 “任何 东西 "” 如 图 
8-79 Bras. 


可 接受 ”任何 东西 O 数字 
O 电子 邮件 地 址 O 数字 从 | 008 | 


图 8-79 设置 “检查 表单 ”对 话 框 


(3) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 现 在 后 台 版 主 登录 页 面 admin login.php 的 设 
计 与 制作 都 已 经 完成 ， 如 图 8-80 所 示 。 


A C:XÁpacheXhtdocsXbbsYXadmin login.php m 回 区 | 


Ur I2 


(body? CForméformi? — [lh |i) Qj 100€ — 4 51T x 147v B K / 1 £P Unicode (UTF-8) 


图 8-80 ”设置 完毕 的 厂 主 登录 页 面 


852 后 台 版 主管 理 


BBS 论坛 管理 系统 的 后 台 版 主管 理 页 面 是 厂 主 由 登录 的 页 面 验证 成 功 后 所 转 到 的 页 面 。 
这 个 页 面 主 要 为 版 主 提供 对 数据 的 新 增 、 修 改 、 删 除 内 容 等 功能 。 后 侣 版 主管 理 页 面 
admin.php 的 内 容 设计 与 BBS 论坛 系统 主页 面 index.php 大 致 相同 ， 不 同 的 是 加 入 可 以 转 到 所 
编辑 页 面 的 链接 。 页 面 效 果 如 图 8-81 所 示 。 

CD 后 人 台 版 主管 理 页 面 admin.php 中 ， 动 态 显 示 部 分 和 index.php 是 一 样 的 ， 所 以 可 以 直 
接 将 index.php 保存 为 admin.php 页 面 ， 然 后 再 加 入 “修改 ”和 “删除 ”的 两 列表 格 。 每 个 讨 
论 主题 后 面部 各 有 一 个 “修改 ”按钮 和 和 “删除” 按钮， 它们 分 别 是 用 来 修改 和 删除 某 个 讨论 主 
题 的 ， 但 不 是 在 这 个 页 面 执 行 ， 而 是 利用 转 到 详细 页 面 的 方式 ， 另 外 打开 一 个 页 面 进行 相应 的 
操作 。 
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8-81 后 分 版 主管 理 页 面 的 设计 效果 
(2) 单 击 admin.php 页 面 中 的 “删除 ”按钮 ， 在 “属性 ”面板 中 设置 “链接 ”如 图 8-82 
所 示 : 


del_title.php?bbs_ID=<?php echo $row. rs bbs['bbs ID']; ?> 
属性 


| 
E Ee IK Eie | 源 文 件 G) images/desle sif Goan] — ~v) 类 O| 天 
m | whs | HEO: Qo s ?g9- 


Aam laaan ”| Bew) — (v iem  |Nu€^A 
A) OOV e| — | Bá —  — gre 


8-82 ”设置 “链接 ”属性 
(3) 单 击 admin.php 页 面 中 的 “修改 ”按钮 ， 在 “属性 ”面板 中 设置 “链接 ”如 图 8-83 
Br: 
upd title.php?bbs ID-«?php echo $row rs bbs['bbs ID']; ?> 


尾 性 


—————————— Ó = 
a Ee ik — Ehe | 源 文 件 G)[inages/write eif logo ROD| — — — — v| 类 GO| 天 
I) ^ | Awhe | HEL) [upd title phpbb OGO B JW 
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8-83 ”设置 “链接 ”属性 
(4) 由 于 讨论 区 的 管理 权限 是 属于 版 主 的 ， 因 此 必须 设 定 本 页 面 “ 限 制 对 页 访问 ”的 
服务 器 行为 。 单 击 “ 服 务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 用 户 身份 验 
证 ”一 “限制 对 页 的 访问 ”命令 ， 打 开 “ 限 制 对 页 的 访问 ”对 话 框 ， 选 择 “ 用 户 名 和 密码 ” 
单 选 按钮 ， 如 果 访 问 被 拒绝 页 面 ， 将 转 癌 admin_login.php， 如 图 8-84 所 示 。 


限制 对 页 的 访问 


基于 以 下 内 容 进 行 限制 : C ”用户 名 和 密码 


8-84 限制 对 页 面 的 访问 设置 


PHP-*-MvySQL*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


susce 删除 讨论 页 面 


删除 讨论 页 面 del_title.php 的 功能 不 只 是 要 删除 所 指定 的 主题 ， 还 要 将 与 此 主题 相关 的 
回复 留言 从 资料 表 bbs ref 中 删除 。 页 面 设 计 效 果 如 图 8-85 所 示 。 
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图 8-85 ”删除 讨论 页 面 的 设计 戏 果 
许 细 操作 步骤 如 下 。 
(1) 打开 删除 讨论 页 面 del_titephp， 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 
上 出 | 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 〈 查 询 )” 的 命令 ， 在 打开 的 “记录 集 ” 对 话 框 中 
单 击 “高 级 ”按钮 ， 进 入 记录 集 高 级 设 定 的 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 SQL i& 
AJ, WME 8-86 所 示 。 
SELECT bbs main.*,bbs ref.* 


FROM bbs main LEFT OUTER JOIN bbs ref ON bbs main.bbs ID-bbs ref.bbs main ID 
WHERE bbs main.bbs ID -'"".Sbbs ID." 


Y 


: SELECT bbs main.*,bbs ref.* FROM bbs main LEFT OUTER JOIN bbs ref 
i - f 1 WHERE b ain. bbs ID 


N bbs main.bbs IlD-bbs ref.bbs main ID bs m 
'*$bbs ID. " 


添加 到 SQL: 


SELECT 


WHERE 


ORDER BY 


dk ”预存 过 程 


8-86 改写 SQL 语句 


人 BBS 论坛 管理 系统 


(2) 上 图 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 admin.php 传递 过 来 的 参数 ， 因 此 
在 该 页 目 动 生成 的 PHP 代码 中 的 第 工行 加 入 如 下 的 变量 赋值 。 


$bbs ID-strval($ GET['bbs ID']; 


(3) 在 设 定 完 记 录 集 绑 定 后 ， 把 rs 记录 集中 的 字段 插入 到 del_title.php KEE, wK 
8-87 所 示 。 


"C: whpachevhtdoesAbbsvdel_title php 


| ”PHP 论坛 管理 系统 I 


i -E 


你 确定 册 除 此 标题 和 内 容 : 


{rs.bbs_title} 


{rs. bbs_content} ^ 
v 


确定 删除 


Copyright @ 2011 www.hbculture.com Inc. All rights reserved. 论坛 之 家 


< u » 
table? <tr> <td> <form. .. > (table? <tr> <td> Qlabel?KCtextares...7] [RI Q 100€ — 4| T85 x 445v 82 K / 2 fb Unicode (UTF-8) — - 


8-87 ”字段 插入 全 del title.php 中 


(4) 在 页 面 中 插入 一 个 隐藏 字 段 bbs ID， 将 这 个 变量 绑 定 全 删除 讨论 页 面 del titlephp 
中 的 隐藏 区 域 bbs_ ID， 如 图 8-88 所 示 。 


IN] Eee [x det 
io) 多 


8-88 ”插入 字段 到 隐藏 域 中 


(5) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 del_title.php 页 面 加 入 “删除 记录 ”的 设置 ， 具 
体 的 设置 如 图 8-89 所 示 。 


首先 检查 是 天 已 定 兴 变量 : EHA m | 
连接 : bbs "m 


表格 : bbs main wv 


xw. sia 


主键 值 : VRL 参数 v| bbs ID 


册 除 后 ， 转 到 : admin. php pls... 


8-89 ”设置 “删除 记录 ”对 话 框 


PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


单 击 “ 确 定 ” 按 钮 ， 完 成 删除 讨论 页 面 的 设置 。 


S50 | 修改 讨论 主题 


修改 讨论 主题 页 面 upd_title.php 的 功能 是 更 新 主题 的 标题 和 内 容 到 bbs. main 数据 表 中 ， 
页 面 设 计 如 图 8-90 所 示 。 


E c:Wapacheht docsbbsupd_title php 


iN 


CIPUE AE P. tul 
T m 
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你 确定 修改 此 标题 和 


确定 修改 


Copyright @ 2011 www hbeulture.com Inc.All rights reserved. 论坛 之 家 


> 
RIY Q 100$ v72l x 430v 62 K / 2 f Unicode (UIF-B) — 


8-90 ”修改 讨论 主题 页 面 效果 


操作 步骤 如 下 。 

(1) 打开 修改 讨论 主题 页 面 upd. title.php， 单 击 “ 绑 定 ” 面 板 上 的 固 按钮 ， 在 弹出 的 菜 
单 中 ， 选 择 “ 记 录 集 《得 询 )” 人 命令， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 高 级 ” 投 钮 ， 
进入 记录 集 高 级 设 定 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 SQL 语句 ， 如 图 8-91 所 示 : 

SELECT bbs main.*,bbs ref.* 


FROM bbs main LEFT OUTER JOIN bbs ref ON bbs main.bbs ID-bbs ref.bbs main ID 
WHERE bbs main.bbs ID -'"".Sbbs ID." 


M 


: |SELECT bbs *, bbs ref.* FROM bbs main LEFT OUTER JOIN bbs ref 
n ur main. n. bbs ID= tb:  ref.bbs main; -ID WHERE bbs | main. bbs ID 
bbs ID." 


添加 到 SQL: 


SELECT 


WHERE 


ORDER BY 


dk ”预存 过 程 


8-91 改写 SQL 语句 


(2) 图 8-91 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 admin.php 传递 过 来 的 参数 ， 因 
此 在 该 页 目 动 生成 的 PHP 代码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 


$bbs ID-strval($ GET[ bbs ID']); > 


(3) 在 设 定 完 记 录 集 绑 定 后 ， 把 记录 集 rs 中 的 字段 插入 到 upd title.php 页 面 上 ， 如 
图 8-92 所 示 。 


V C: hpache\htdocs\bbs\upd_ title. php 


你 确定 修改 此 标题 和 内 容 : 


{rs.bbs_title} 


{rs. bbs_content} 


确定 修改 


Copyright @ 2011 waw. hbculture.com Inc.All rights reserved. 论坛 之 家 


< liii 
> <td> <form. . . > <table> tr? <td> Label? Ktextarea...7] O S) Q 100$ 4/721 x 430v 63 K / 2 fU Unicode (UTF-8) — - 


图 8-92 ”字段 插入 至 upd title.php 中 
(4) 在 页 面 中 搬入 一 个 隐藏 字段 bbs ID ， 将 这 个 变量 绑 定 至 修改 讨论 主题 页 面 
upd_title.php 中 的 隐藏 域 bbs_ID， 如 图 8-93 所 示 。 


AI parkeu 
bosm | EM) [php echo $row rsl bbs IY J; ?多 


图 8-93 ”插入 字段 到 隐藏 区 域 中 


(5) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 upd_title.php 加 入 “更 新 记录 ”的 设置 。 在 “更 
新 记录 ”对 话 框 中 ， 输 入 如 图 8-94 所 示 的 设置 。 


TA’ B: forni v 
连接 : bbs v 
更 新 表格 : D —— ' 


: [bbs ID' H 'FORM.bbs EA Ei 
'bbs title "à FORM. bbs giia Ex Ec 
"bbs c — Z. 5; CBUIBTE bur 


S (B: | FORM. bbs content v 
提交 为 : | 文本 INE: 


在 更 新 后 , 转 到 :laninphp | (WE...) 


图 8-94 设置 “更 新 记录 ”对 话 框 


PHP 


(60 单 击 “ 确 定 ” 按 钮 ， 完 成 修改 讨论 主题 页 面 的 设置 。 


S 删除 回复 页 面 


删除 回复 页 面 del reply.php 功能 是 将 表单 中 的 数据 从 网 站 的 数据 表 bbs_ref 中 删除 。 其 


主要 目的 是 ， 管 理 员 对 一 些 不 文明 和 非法 的 回复 信息 进行 删除 。 其 页 面 设计 效果 如 图 8-95 
所 示 。 


| DW 
| Hd) iu) HEC GÁACO ao EO 
igneum 
ATP wy rt 
| tA | RE 和 C. illia De cos FREN 
|| e m 本 CS E: da sa bë 


0 b MAc Wom Rm 
Lo E ee bet dal tipi. ph 


Vom —— y TRAM v 
ECARE ACC He 


| coc EE CREE = i " ——É—— BÉ: 
edr? able? Gr Ot: aretiral? ka mr E Waiccda O-A 


WE O. 一 
| € mi. | tmm [E "nx 


= BF 1z E ns ns WT) | 
"leo mee 


| Ep ee sromu ~ Xo aano mem] —— 
Gw BEC = :-00| x) Fao 


dcm ma) [fort «| EEL | 


8-95 del reply.php 页 面 的 设计 效果 
其 详细 的 操作 步骤 如 下 。 


COD 打开 后 台 版 主管 理 页 面 admin.php 单 击 标题 ， 进 入 del replyphp 页 面 。 实 现 此 功能 
时 ， 只 要 在 标题 的 属性 栏 将 链接 到 的 页 面 参数 修改 为 del_reply.php 整 可 以 ， 如 图 8-96 Drs. 


属性 

ERO) 类 CPP UE 
bs mo EEO MESTAT oO Bg ~ 
国 4m KFORU v æv) | AGO] WREG [ — | 

m| nn] 


cj je  £&B(DSNA v| mOD| 40 wawo 
图 8-96 属性 链接 设置 


(2) 在 del reply.php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 外 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 
录 集 〈 答 询 )” 人 命令， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 高 级 ”按钮 ， 进 入 记录 集 遍 级 
WER, KIAH SQL 语句 改 成 以 下 的 SQL 语句 ， 如 图 8-97 所 示 。 

SELECT bbs main.*,bbs ref.* 


FROM bbs main LEFT OUTER JOIN bbs ref ON bbs main.bbs ID-bbs ref.bbs main ID 
WHERE bbs main.bbs ID -'"".Sbbs ID." 


(QL*-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(ms 可 (EX 


: [SELECT bbs main.*, bbs ref.* FROM bbs main LEFT OUTER JOIN bbs ref 
ON bbs m ain. bbs ID-bbs ref. bbs main ID WHERE bbs main.bbs ID F 


Dow 


数据 库 项 : EI 添加 到 SAL: 
FEET: 
d. Toi 


图 8-97 改写 SQL 语句 


(3) 在 该 页 目 动 生 成 的 PHP 代码 中 的 第 1 行 加 入 如 下 的 变量 赋值。 


$bbs ID-strval($ GET['bbs ID']); 


(4) 在 设 定 完 记录 集 绑 定 后 ， 把 记录 集 rs 中 的 字段 插入 到 del reply.php WEE, 


8-98 所 示 。 


如 图 
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8-98 ”字段 插入 至 del reply.php 中 
C5) 在 页 面 中 插入 一 个 隐藏 字段 bbs ID， 将 这 个 变量 绑 定 全 删除 回复 页 面 del reply.php 
中 的 隐藏 区 域 pbs_ID， 如 图 8-99 所 示 。 


IN] parne 
av 多 


图 8-99 插入 字段 到 隐藏 域 中 


| PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(6) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 del_reply.php 页 面 加 入 “删除 记录 ”的 设 定 ， 只 
要 在 “删除 记录 ”对 话 框 中 ， 输 入 如 图 8-100 所 示 的 设置 。 


首先 检查 是 否 已 定义 变量 : «[ | 
表格 : s re 


主键 列 : bbs ref ID v 数值 
ESRB: URL 和 参数 {v bbs ref ID | 


删除 后 ， 转 到 : admin. php 


8-100 ”设置 “删除 记录 ”对 话 框 


Ax HI BBS 论坛 系统 的 开 友 制作 ， 读 者 可 以 任 信 学 习 a 到 的 知识 来 做 一 个 个 性 
化 的 论坛 ， 通 过 加 入 更 多 的 技术 ， 可 以 完成 更 强大 的 Web 程序 。 


第 性】 章 “PHP 网 上 购物 系统 前 台 


本 章 介 绍 一 个 使 用 PHP. 开发 的 大 型 电子 商务 网 站 的 建设 实例 。 网 上 购物 系统 是 由 专业 
网 络 技术 公司 开发 ， 是 拥有 产品 发 布 、 订 单 处 理 、 购 物 车 等 功能 组 合 而 成 的 复杂 动态 系统 。 
它 必 须 拥 有 会 员 系 统 、 碍 询 系统 、 购 物流 程 、 会 员 服务 、 后 人 台 管 理 等 功能 模块 ， 从 技术 角度 
来 说 ， 主 要 是 通过 购物 车 实现 电子 商务 功能 。 本 章 主 要 介绍 使 用 PHP 进行 网 上 购物 系统 前 
台 开 发 的 方法 ， 将 系统 地 介绍 网 上 购物 系统 的 设计 、 数 据 库 的 规划 以 及 津 用 的 儿 个 功能 模块 
前 台 的 开发 方法 。 


MATIE A 


本 草 主 要 掌握 以 下 知识 点 : 


网 上 购物 系统 的 功能 分 析 与 模块 设计 
网 上 购物 系统 数据 库 的 设计 搭建 
购物 车 首页 的 设计 

商品 相关 动态 页 面 设计 
商品 结算 功能 设计 
订单 查询 功能 设计 


Q Qul 


A PHP+MySQL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


_ Section _ 
网 上 购物 系统 分 析 与 设计 


网 上 购物 系统 是 一 个 比较 庞大 的 系统 ， 拥 有 会 员 系 统 、 碍 询 系统 、 购 物流 程 、 会 员 服 
务 、 后 台 管 理 等 功能 模块 。 为 了 能 系统 化 地 介绍 使 用 PHP 建设 电子 商务 网 站 的 过 程 ， 本 章 
将 模拟 一 个 实用 的 购物 网 站 的 建设 过 程 为 例 ， 来 详细 介绍 网 站 想 拥 有 一 个 网 上 购物 系统 必须 
做 哪些 具体 工作 。 


| 购物 系统 分 析 


商务 实用 型 网 站 是 在 网 络 上 建立 一 个 虚拟 的 购物 商场 ， 让 访问 者 在 网 络 上 购物 。 网 上 购 
物 以 及 网 上 商店 的 出 现 ， 避 免 了 挑选 商品 的 烦 开 过 程 ， 让 人 们 的 购物 过 程 变 得 轻松 、 人 快捷、 
方便 ， 适 合 现代 人 快 节奏 的 生活 需求 ， 同 时 又 能 有 效 地 控制 “商场 ”运营 的 成 本 ， 开 辟 了 
一 个 新 的 销售 渠道 。 本 实例 是 使 用 PHP-MySQL 直接 用 手写 程序 完成 的 实例 ， 完 成 的 首页 
如 图 9-1 所 示 。 


图 9-1 开发 设计 的 网 上 购物 系统 首页 效果 


对 于 该 网 站 的 功能 说 明 如 下 。 

CD 采取 会 员 制 保证 交易 的 安全 性 。 

(2) 开发 了 强大 的 搜索 以 及 高 级 个 询 功能 ， 能 够 快捷 地 找到 感 兴 趣 的 丙 品 。 

(3) 会员 购 物流 程 : 浏览 、 将 商品 放 入 购物 车 、 去 收银 人 台 。 每 个 会 员 有 目 己 专用 的 购物 车 ， 
可 随时 订购 目 己 中 意 的 商品 、 结 账 完成 购物 。 购 物 的 流程 是 指导 编写 购物 车 系统 程序 的 主要 依据 。 

(4) 完善 的 会 员 中 心服 务 功能 : 可 随时 查看 账目 明细 、 订 单 明 细 。 

(50 设计 会 员 价 商品 展示 ， 能 够 显示 企业 近期 所 促销 的 一 些 会 员 价 商品 。 

(6) 人 性 化 的 会 员 与 网 站 留言 以 及 产品 评价 系统 ， 可 以 方便 会 员 与 网 站 管理 员 之 间 的 沟通 。 


PHP 网 上 购物 系统 前 人 台 


CD 后 台 管 理 使 用 本 地 数据 库 ， 保 证 购物 订单 被 安全 、 及 时 、 有 效 地 处 理 。 强 大 的 统计 
分 析 功 能 ， 便 于 管理 员 及 时 了 解 财务 状况 、 销 售 状况 。 


SA | 功能 模块 分 析 


通过 对 系统 功能 的 分 机， 得 到 网 站 的 网 上 购物 系统 主要 由 如 下 功能 模块 组 成 。 

(1) 前台 网 上 销售 醒 基 。 指 客户 在 浏览 亏 中 所 看 到 的 、 可 和 直接 与 店主 面对面 的 销售 程 
序 ， 包 括 浏 览 商 品 、 订 购 商 品 、 碍 询 订 购 、 购 物 车 等 功能 。 

(2) 后 台数 据 录 入 模块 。 前 台所 销售 商品 的 所 有 数据 ， 其 来 源 部 是 后 台所 录入 的 数据 。 

G) 后 台数 据 处 理 功 能 模块 。 它 是 相对 于 前 台 网 上 销售 模块 而 言 ， 网 上 销售 的 数据 都 放 
在 铀 售 数据 库 中 ， 对 这 部 分 的 数据 进行 处 理 ， 是 后 台数 据 处 理 模块 的 功能 。 

(4) 用 户 注册 功能 模块 。 用 户 不 一 定 立 即 就 要 买 东西 ， 可 移 注 册 ， 任 何 时候 都 可 以 来 买 
东西 。 用 户 注 册 的 好 处 在 于 买 完 东 西 后 无 须 再 输入 一 大 堆 个 人 信息 ， 只 须 将 账号 和 密码 输入 
WEJ EA T o 
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随时 俘 询 账单 处 理 情况 ， 了 解 实时 的 物流 信息 。 

(60 会 员 留 言 模 块 。 客 户 能 及 时 反馈 信息 ， 管 理 员 能 在 后 台 实 现 回 复 的 功能 ， 真 正 做 到 
处 处 为 顾客 看 想 。 


SEDES 网 站 整体 规划 


在 制作 网 站 之 前 ， 首 先 要 把 设计 好 的 网 站 内 容 放 年 在 本 地 计算 机 的 便 盘 上 ， 为 了 方便 站 
凡 的 设计 及 上 传 ， 设计 好 的 网 页 都 应 存储 在 一 个 目录 下 ， 再 用 合理 的 文件 来 来 绾 理 文档 。 在 
本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 夹 ， 然 后 在 
其 中 再 创建 多 个 子 文 件 夹 ， 最 后 将 文档 分 关 存 储 到 相应 的 文件 夹 下 。 读 者 可 以 打开 光盘 中 的 
素材 ， 看 第 9 章 的 站 点 文档 结构 及 文件 夹 结构 ， 设 计 完 成 的 结构 如 网 9-2 所 示 。 
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图 9-2 网 站 文档 及 文件 夹 结构 
从 站 氮 规划 的 文件 夹 及 完成 的 页 和 面 出 发 ， 分 别 对 需要 设计 的 页 面 功能 分 析 如 表 9-1 所 示 。 


* 


hj xh Bp = x ft 
addgouwuche.php 
agreereg.php 
bottom.php 
changeuser.php 
changeuserpwd.php 
chkuser.php 
chkusernc.php 
conn/conn.php 
deleteall.php 
finddd.php 
findpwd.php 
serchorder.php 
function.php 
gouwuche.php 
gouwusuan.php 
highsearch.php 
index.php 
left.php 
logout.php 
lookinfo.php 
openfindpwd.php 
reg.php 
removegwc.php 
savechangeuserpwd.php 
savedd.php 
savepj.php 
savereg.php 
saveuserleaveword.php 
showdd.php 
showfenlei.php 
gonggao.php 
gonggaolist.php 
showhot.php 
shownewpr.php 
showpp.php 
showpl.php 
showpwd.php 
showtuijian.php 
top.php 
usercenter.php 


userleaveword.php 
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站 点 规划 的 页 面 功能 分 析 


主要 功能 
添加 订购 的 商品 到 购物 车 gouwuche.php 页 面 
同意 注册 页 面 
网 站 底部 版 权 
用 户 注 册 信 息 更 改 页 面 
更 改 登录 密码 页 面 
登录 身份 验证 页 面 
检查 昵称 是 否 被 用 文件 
conn 文件 夹 下 的 数据 库 连 接 文件 
删除 用 户 处 理 页 面 
订单 查询 页 面 
找 回 密码 功能 的 页 面 
租 找 到 商品 显示 页 面 
系统 调用 的 利用 函数 
购物 车 页 面 
收银 台 结 算 页 面 
高 级 查找 页 面 
网 站 购物 车 首页 
用 户 及 公告 系统 
用 户 退 出 页 面 
详细 商品 信息 
找 回 密码 问题 答案 页 面 
用 户 注册 开始 页 面 
购物 车 移 除 指定 商品 页 面 
更 改 用 户 密码 页 面 
保存 用 户 订单 页 面 
保存 商品 评价 页 面 
保存 用 户 注册 信息 
保存 用 户 留 言 员 和 面 
显示 详细 订单 页 面 
商品 分 类 显示 页 面 
显示 详细 公告 内 容 页 面 
公告 多 列 分 页 显示 
热门 商品 页 面 
最 新 商品 页 面 
商品 销售 排行 页 面 
商品 评论 分 页 显示 页 面 
用 户 找 回 的 密码 页 面 
推荐 商品 页 面 
网 站 顶部 导航 条 
会 员 中 心 页 面 
发 表 留 言 页 面 


EIE 
E 
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从 上 面 的 分 析 统 计 来 看 ， 该 网 站 前 合共 由 41 个 页 面 组 成 ， 几 乎 涉及 了 动态 网 站 建设 所 
有 的 功能 设计 。 


JA 购物 系统 数据 库 设 计 2 


网 上 购物 系统 的 数据 库 也 是 比较 庞大 的 ， 在 设计 的 时 候 需 要 从 使 用 的 功能 模块 入 手 ， 可 
以 分 别 创 建 不 同 命名 的 数据 表 ， 命 名 的 时 候 也 要 与 使 用 的 功能 命名 相配 合 ， 方 便 后 面相 关 页 
面 设计 制作 时 的 调用 。MySQL 数据 库 的 制作 方法 在 前 面 的 革 市 中 也 介绍 过 很 多 次 ， 本 曹 市 


国 dz (VAROMARC2S 


9-3 ££ db shop 数据 库 


SELLO 设计 数据 表 


数据 库 db_shop 里 是 根据 开发 网 站 的 几 大 动态 功能 来 设计 不 同 数据 表 的 ， 本 实例 需要 创 
建 8 个 不 同 的 数据 表 。 下 面 分 别 介 绍 这 些 数据 表 的 功能 及 设计 的 字段 要 求 。 

(1) tb admin 是 用 来 储存 后 台 管 理 员 的 信息 表 ， 在 MySQL 命令 栏 输入 创建 该 数据 表 的 
A P: 


CREATE TABLE 'tb admin' ( 
id' int(4) NOT NULL DEFAULT '0', 
name' varchar(25) DEFAULT NULL, 
pwd' varchar(50) DEFAULT NULL, 
PRIMARY KEY (1d') 


ENGINE=MyISAM DEFAULT CHARSET-2gb2312; 


WWW tb admin 数据 表 如 图 9-4 PZR. 


£& Table — [tb admin] — [db shop on localhost] 


PHP«*MySQL-*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


Object Ed A | Properties | Eields | Indices | Triggers | Data | Dependencies | DDL | 


E db. shop on localhost [ v | | 
| asia 1 Eid INTEGER — 4 0 
| E tb. admin w E Iname VARCHAR 25 0 


General mg 习 pwd VARCHAR 50 ü 


ig) Refresh 
学 Compile 
ĝo Grants on table 


©) Show SQL help 
(b Table Editor options 
由 [E] Restore defaut size 


Tools 


Es Truncate table 


Fields 


ES Add new field 
zd Edit selected field 


| Field Name Field Type Size Precision Mot Null Default 


图 9-4 后 台 管 理 员 表 tb admin 


(2) tb dingdan 是 用 来 储存 会 员 在 网 上 下 的 订单 的 详细 内 容 表 ， 在 MySQL 命令 栏 输入 


创建 该 数据 表 的 代码 如 下 : 


CREATE TABLE 'tb dingdan' ( 
ld int(4) NOT NULL AUTO INCREMENT, 
dingdanhao' varchar(125) DEFAULT NULL, 
Spc varchar(125) DEFAULT NULL, 
Slc varchar(125) DEFAULT NULL, 
'shouhuoren' varchar(25) DEFAULT NULL, 
Sex varchar(2) DEFAULT NULL, 
dizhi' varchar(125) DEFAULT NULL, 
'youbian' varchar(10) DEFAULT NULL, 
tel' varchar(25) DEFAULT NULL, 
emall varchar(25) DEFAULT NULL, 
'shff varchar(25) DEFAULT NULL, 
'"Zfff varchar(25) DEFAULT NULL, 
leaveword' mediumtext, 
tme varchar(25) DEFAULT NULL, 
xiadanren' varchar(25) DEFAULT NULL, 
zt varchar(50) DEFAULT NULL, 
total varchar(25) DEFAULT NULL, 
PRIMARY KEY (1d') 

) 


ENGINE=MyISAM AUTO INCREMENT-z105 DEFAULT CHARSET-gb2312; 


设计 的 tb_dingdan 数据 表 如 图 9-5 所 示 。 


JA ETE Eu C. $95 CUMTHA 


n Table [tb dingdan] 


oc A ^ _ Properties Fields inces | Triggers Data | Dependencies DOL 
Field Name Field Type 
d NIEGEI 


| db shop co loceinost | vw. 


gaaaagaaaaaaaaagagaoaor 
EEEEEEEEEEEEEEEEDE 
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(3) tb gonggao 是 用 来 保存 网 站 公告 的 信息 表 ， 在 MySQL 命令 栏 输入 创建 该 数据 表 的 
代码 如 下 : 


CREATE TABLE 'tb gonggao' ( 
id int(4) NOT NULL AUTO INCREMENT, 
'title' varchar(100) DEFAULT NULL, 
'content' text, 
'time' varchar(25) DEFAULT NULL, 
PRIMARY KEY (1d') 


) 
ENGINE=MyISAM AUTO INCREMENTZ28 DEFAULT CHARSET-gb2312; 


设计 的 tb. gonggao 数据 表 如 图 9-6 所 示 。 


£ Table — [tb_gonggao] - [db shop on localhost] 


Object 
一 Field Type Size Preci... Mot... Default Comment 
| |H db shop on localhost [ v m " 
INTEGER 4 0 Null 


ic 0 
E tb_gonggao «B ^ VARCHAR 100 0 | [7] Nul 


cu - E content TEXT o 0 Om 
: 一 ,图 time VARCHAR 25 | | Nul 
; | | 


[a] Refresh 

if Compile 

Qj» Grants on table 

éa Print 

Q9) Show SQL help 

(il Table Editor options 
回 Restore default size 


色 9-6 网 站 公告 表 tb_gonggao 


(4) tb_leaveword 是 用 户 给 网 站 管理 员 留 言 的 数据 表 ， 在 MySQL 命令 栏 输入 创建 该 数 


据 表 的 代 公 如下: 


CREATE TABLE 'tb leaveword' ( 
ld int(4) NOT NULL AUTO INCREMENT, 
userid' int(4) DEFAULT NULL, 
title" varchar(100) DEFAULT NULL, 


'content' text, 


'"PHP*MySQL*Dreamweaver 58:385 71988 


tme' varchar(25) DEFAULT NULL, 
PRIMARY KEY (1d') 


) 
ENGINE=MyISAM AUTO INCREMENT-z16 DEFAULT CHARSET-gb2312; 


设计 的 tb leaveword 数据 表 如 图 9-7 所 示 。 


$ Table — [tb leaveword] — [db shop on localhost] 

Object Al | Properties | Fields | Indices || Triggers | Data | Dependencies | DDL | 
= Field Name Field Type Size Precisi... Not Null Default 
[4 db shop on localhost [ w 
Efi tb leaveword v : INTEGER 


cea "EE 
s |TEXT 
| [A] Refresh | i (VARCHAR 
学 Compile 5 


Qj» Grants on table 

ca Print 

Q9) Show SQL help 

他) Table Editor options 
[E Restore default size 


9-7 用 户 留 言 表 tb leaveword 
(5) tb pingjia 是 用 户 对 网 上 商品 的 评价 表 ， 在 MySQL 命令 栏 输入 创建 该 数据 表 的 代码 
如 下 : 


CREATE TABLE 'tb_pingjia' ( 
ld int(4) NOT NULL AUTO INCREMENT, 
userid' int(4) DEFAULT NULL, 
'spid' int(4) DEFAULT NULL, 
'title' varchar(100) DEFAULT NULL, 
'content' text, 
tme' varchar(25) NOT NULL DEFAULT ", 
PRIMARY KEY (1d') 


) 
ENGINE=MyISAM AUTO INCREMENTZ20 DEFAULT CHARSET-gb2312; 


设计 的 tb. pingjia 数据 表 如 图 9-8 所 示 。 
导 Table — [tb pingjia] — [db shop on localhost] 


[3 db shop on localhost [ v 
EF tb. pingjia v 


General - 


| [g] Refresh 
| g Compile 


VARCHAR 


Qj» Grants on table 

é% Print 

Q9) Show SAL help 

(5 Table Editor options 
回 Restore default size 


Tools 


Ef Truncate table 
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(6) tb shangpin 是 商品 表 ， 购 物 系统 中 核心 的 产品 发 布 、 订 购 时 的 结算 都 要 调用 该 数据 
表 的 内 容 ， 在 MySQL 命令 栏 输 入 创建 该 数据 表 的 代码 如 下 : 


CREATE TABLE 'tb shangpin' ( * 
id int(4) NOT NULL AUTO INCREMENT, > 
'mingcheng' varchar(25) DEFAULT NULL, 
jianjie' mediumtext, 

'addtime' varchar(25) DEFAULT NULL, 
dengji' varchar(5) DEFAULT NULL, 
xinghao' varchar(25) DEFAULT NULL, 
tupian' varchar(200) DEFAULT NULL, 
'shuliang' int(4) DEFAULT NULL, 

cishu int(4) DEFAULT NULL, 

tuijian' int(4) DEFAULT NULL, 

typeid' int(4) DEFAULT NULL, 
'huiyuanjia' varchar(25) DEFAULT NULL, 
'shichangjia' varchar(25) DEFAULT NULL, 
pinpai' varchar(25) DEFAULT NULL, 
PRIMARY KEY (1d') 


) 
ENGINE=MyISAM AUTO INCREMENTZ222 DEFAULT CHARSET-gb2312; 


设计 的 tb_shangpin 数据 表 如 图 9-9 所 示 。 


Hg Table ~ [th shnangpin] ~ [dh, zhop on localhost] 
objeet Ig A  properbes | Eds indices  Trgoers Data | Dependercies | DOG 
Field Name Feld Type ue Precisi.,, Not Mg Detout 
iE INTEGER " Ô 
dr; tb shengen El D] rnirggcheng VARCHAR |25 


G al AS N] sree MEDUMTEXT O 
IT VARCHAR 


到 Retresh jd] dene VARCHAR 
Core 加 :noheo VARCHAR 
Qi» Granis on tatie I| tupinn VARCHAR 
. Print D] siang INTEGER 


| dh, shop on benhos |. ve 


X 


úh 


-ih 


- 
«4j Show SOL help t] ashu INTEGER 
tujan INTEGER 
(d; Takie Editor options una 
U] tvpesd NTEGER 
FA Restore deim sime 
D] huueees VARCHAR 


LIE SE MEL ILI 


TEN. 


Olole Olola Olola olo c o 


| shichangim VARCHAR 
d] pnpa VARCHAR 


Uu 


Dag Truncate takie 


ij Add new neid 


(B) Edit selected field 


图 9-9 商品 表 tb shangpin 
(7) tb_type 是 商品 的 分 类 表 ， 在 MySQL 命令 栏 输入 创建 该 数据 表 的 代码 如 下 : 


CREATE TABLE 'tb_type' ( 
id int(4) NOT NULL AUTO INCREMENT, 
typename' varchar(25) DEFAULT NULL, 
PRIMARY KEY (1d') 


) 
ENGINE=MyISAM AUTO INCREMENT-Z28 DEFAULT CHARSET-gb2312; 


WWW tb type 数据 表 如 图 9-10 所 示 。 


I Table ~ [th type] ~ [db shop om lacnlhozt ] 


Object P cB properties | [ekis | indices | Triggers | Data | Dependencies DOC. 


— ` Fiski Name Fiki Type Sire — Precis — Not Nud Oeinut Comment 
[J do shop on locsihost |. se 


EG type 


v 
General 5 
| A) Retresh 
Jf Compie 
Qi» Granis on table 


9-10 商品 分 类 表 tb type 


(8) tb user 是 用 来 保存 网 站 会 员 注册 用 的 数据 表 ， 在 MySQL 命令 栏 输 入 创建 该 数据 表 


的 代码 如 下 : 


CREATE TABLE 'tb user ( 
ld int(4) NOT NULL AUTO INCREMENT, 
name' varchar(25) DEFAULT NULL, 
pwd' varchar(50) DEFAULT NULL, 
dongjie' int(4) DEFAULT NULL, 
'email' varchar(25) DEFAULT NULL, 
'sfzh' varchar(25) DEFAULT NULL, 
tel' varchar(25) DEFAULT NULL, 
qq varchar(25) DEFAULT NULL, 
'tishi' varchar(50) DEFAULT NULL, 
'huida' varchar(50) DEFAULT NULL, 
'dizhi' varchar(100) DEFAULT NULL, 
youblan varchar(25) DEFAULT NULL, 
regtime' varchar(25) DEFAULT NULL, 
truename' varchar(25) DEFAULT NULL, 
pwdl varchar(50) DEFAULT NULL, 
PRIMARY KEY (1d') 

) 

ENGINE=MyISAM AUTO INCREMENT-245 DEFAULT CHARSET-2gb2312 


设计 的 tb_user 数据 表 如 图 9711 PTR o 


| RJ [tb urer] |db shep om localhort] 


E 


imimiuimimimimimimimiumimm 


SE 


Ee 
Bols dood do als dal 


9-11 网 站 会 员 注 册 表 tb user 


? 
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上 上面 设计 的 数据 表 属 于 比较 复杂 的 数据 表 ， 数 据 表 之 间 主 要 通过 产品 的 类 别 ID 关联 ， 
建立 网 站 所 需要 的 主要 内 容 信息 ， 都 能 储存 在 数据 库 里 面 。 


J22 定义 购物 车 站 点 J © 


定义 购物 车 系统 站 点 的 具体 操作 步骤 如 下 。 
(C1) 首先 在 CAApacheMitdocs 路 径 下 建立 shop 文件 来， 如 图 9-12 MaR, KENNA E 
的 PHP 程序 文件 都 将 放 在 该 文件 夹 下 。 


QAE- O- T Dusk Dirx |E 
地 址 0) [^ C: XApache*htdocs 


XIAEYPIXÉES e 


m] 重 命名 这 个 文件 来 
让 移动 这 个 文件 来 


复制 这 个 文件 来 
5] REST SCHECNGRSI 
e 


i 共享 此 文件 夹 


O 以 电子 邮件 形式 发 送 
该 文件 来 内 的 立 件 
K 删除 这 个 交 件 夹 


ME 1 个 对 象 


图 9-12 建立 站 点 文件 夹 shop 
(2) 打开 Dreamweaver CS $.35， 选 择 荣 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 9-13 所 示 。 
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9-13 “管理 站 点 ”对 话 框 


(3) Hab “新 建 ” 按 钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 设置 。 
“站 点 名 称 ” shop. 


'PHP*MvySQL-4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


“本 地 站 点 文件 来” — CAApacheMtdocsNshop. 
如 图 9-14 所 示 。 
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几 9-14 建立 shop 站 点 


(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 薄 |， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 9-15 所 示 的 参数 设置 。 

“服务 堪 名 称 ” shop。 

“连接 方法 ”本 地 /网 络 。 

“HRE aLI”: CNApacheMtdocs V. 

“Web URL”: http://127.0.0.1/shop/. 


DRAE shop 


图 9-15 RA “IA” WWR 


(5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同步 
信息 ” 复 选 按钮 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 9-16 PTR. 


站 点 设置 对 锚 pp 
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图 9-16 设置 “高 级 ”选项 卡 
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(6) 单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 按钮 ， 
如 图 9-17 所 示 。 


ETE Web 上 的 nm. Worse WR 
务 提供 商 qon) T Web 
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9-17 设置 “服务 器 ”参数 


单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 完 成 Dreamweaver CS 5.5 测试 shop 网 页 
的 网 站 环境 设置 。 


Seer 数据 库 连接 


数据 库 设 计 之 后 ， 需 要 将 数据 库 连 接 到 网 页 上 ， 这 样 网 页 才能 调用 数据 库 和 储存 相应 的 
信息 。 用 PHP 开发 的 网 站 ， 一 般 将 数据 库 连 接 的 程序 代码 文件 命名 为 conn.php。 在 站 点 文 
件 夹 创建 conn.php 空白 页 面 ， 按 如 图 9-18 所 示 输 入 数据 库 连 接 代码 。 


四 C: \Apachethtdocs\shopiconniconn. php. (XHTML) -0x 
E 


r 


nn=mysql_connect ("localhost"”, “root”, “admin”) or die( 

FUP) mysql. error); 

mysql select db("db shop',$conn) or die ("$ti Eib lR". 
nysql error(): 

mysql query("set character set gb2312"); 

mysql query("set names gb2312"); 
?> 
| 


E E 


四 
y 


rn 


«« 


1KY1 秒 简体 中 娘 (GB2312)  - 


图 9-18 输入 数据 库 连 接 代码 
对 于 本 连接 的 程序 说 明 如 下 : 


<?php 

$conn=mysql_connect("localhost","root","admin") or die( 25315 PE Hg 2$ s XE Beth vx" mysql. error()); 
/设置 数据 库 连 接 ， 本 地 服务 器 ， 用 户 名 为 root， 密 码 为 admin， 如 果 连 接 错 误 调 用 mysql error 
PRA. 


mysql select. db("db. shop",$conn) or die(" 数 据 库 访 问 错误 ".mysqlL_errorO); 
/连接 db. shop 数据 库 ， 如 果 连 接 错 误 调 用 mysql. error. 
mysql query("set character set gb2312"); 
mysql query("set names gb2312"); 


i 


ema m 


^ PHP 
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// 设 置 数 据 库 的 字体 为 gb2312 即 中 文 简体 。 


2> 


读者 使 用 时 如 末 需 要 更 改 数据 库 名 称 ， 上 只 需要 将 该 页 和 面 中 的 db_shop 做 相应 的 更 改 即 可 
实现 ， 同 时 用 户 名 和 密码 和 在 本 地 安 朔 的 用 户 名 和 密码 要 保持 一 致 。 


po] ub E Da 动态 功能 


对 于 一 个 网 站 系统 来 襄 ， 需 要 一 个 主页 面 来 给 用 户 进 行 注 册 、 搜 索 需 要 订购 的 商品 、 网 
上 浏览 商品 等 操作 。 实 例 的 首页 index.php 主要 由 fontcss. top.php. left_menu.php、 
bottom.php 等 共 4 个 二 级 页 面 组 合 而 成 。 本 小 节 介 绍 包 括 index.php 在 内 的 5 个 页 面 的 设计 。 


-31 网 站 的 样式 表 


任何 网 站 如 果 想 达到 美观 的 效果 ， 痢 是 要 经 过 专业 的 网 页 布局 设计 。 实 例 按 传 统 的 电子 
商务 网 站 布局 方式 进行 布局 ， 文 字样 式 的 美化 设计 是 使 用 样式 表 来 直接 设计 的 ， 实 例 的 样式 
表 保 存在 css 文件 夹 下 。 

(I) 运行 Dreamweaver CS 5.5 软件 ， 打 开 和 制作 到 这 一 步 的 站 点 文件 来 。 执 行 末 单 “ 文 
件 ” 一 “新 建 ” 命 令 ， 打 开 “ 新 建文 档 ” 对 话 框 ， 选 择 “ 罕 白 页 ”选项 卡 中 “页 面 类 型 ”下 
拉 列 表 框 中 的 CSS， 然 后 单 击 “ 创 建 ” 按 钮 创建 新 页 面 ， 如 网 9-19 所 示 。 在 网 站 css 目录 中 
新 建 一 个 名 为 font.ess 的 网 页 并 保存 。 
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图 9-19 创建 css 文件 


(20 进入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 创建 代码 删除 ， 然 后 加 入 如 下 代码 : 


A:link { 
COLOR: 2006699; TEXT-DECORATION: none 
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A:visited { 
COLOR: #006699; TEXT-DECORATION: none 
j 


A:active { ~Y 
COLOR: #006699; TEXT-DECORATION: none ©) 
} 
A:hover { 
COLOR: #000000 
} 
BODY { 
margin-top: 0px; 
} 
TD,TH { 
FONT-SIZE: 12px; COLOR: #006699; 
} 
/网 页 的 链接 及 基础 属性 。 


.buttoncss { 


"onc 


font-family: "Tahoma", "宋体 "; 
font-size: 9pt; color: 44003399; 
border: 1px #003399 solid; 
color:006699; 
BORDER-BOTTOM: #93bee2 1px solid; 
BORDER-LEFT: #93bee2 1px solid; 
BORDER-RIGHT: #93bee2 1px solid; 
BORDER-TOP: #93bee2 1px solid; 
background-color: #e8f4ff; 
CURSOR: hand; 
font-style: normal ; 
j 
inputcss { 
font-size: Opt; 
color: #003399; 
font-family: "R"; 
font-style: normal; 
border-color: 493BEE2 #93BEE2 #93BEE2 #93BEE2 ; 
border: 1px #93BEE2 solid; 
j 
inputcssnull { 
font-size: Opt; 
color: #003399; 
font-family: "宋体 "; 
font-style: normal; 
border: Opx #93BEE2 solid; 
j 
.scrollbar( 
SCROLLBAR-FACE-COLOR: 4£FFDD22; 


/"PHP- 
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FONT-SIZE: Opt; 
SCROLLBAR-HIGHLIGHT-COLOR: £69BC2C; 
SCROLLBAR-SHADOW-COLOR: 加 9BC2C; 
SCROLLBAR-3DLIGHT-COLOR: £69BC2C; 
SCROLLBAR-ARROW-COLOR: #ffffff; 
SCROLLBAR-TRACK-COLOR: £69BC2C; 
SCROLLBAR-DARKSHADOW-COLOR: #69BC2C 


j 


.scrollbar( 
SCROLLBAR-FACE-COLOR: 4£FFDD22; 
FONT-SIZE: Opt; 
SCROLLBAR-HIGHLIGHT-COLOR: £69BC2C; 
SCROLLBAR-SHADOW-COLOR: £269BC2C; 
SCROLLBAR-3DLIGHT-COLOR: £69BC2C; 
SCROLLBAR-ARROW-COLOR: #ffffff; 
SCROLLBAR-TRACK-COLOR: £269BC2C; 
SCROLLBAR-DARKSHADOW-COLOR: #69BC2C 


} 
/网 页 表单 对 象 的 样式 设置 


通过 上 面 样式 文件 的 建立 ， 可 以 将 整个 网 站 的 样式 统一 ， 起 到 美化 整个 网 站 的 效果 。 
| 建立 搜索 导航 ) 


导航 频道 是 网 站 建设 中 很 重要 的 部 分 ， 通 各 情况 下 ， 一 个 网 站 的 页 面 会 有 几 十 个 ， 更 大 
型 一 点 的 可 能 会 达到 几 千 个 甚至 几 万 个 ， 每 个 页 面 都 会 有 导航 栏 。 但 是 ， 在 网 站 后 期 维护 或 
者 需要 更 改 的 时 候 ， 这 个 工作 量 就 会 变 得 很 大 。 所 以 为 了 方便 ， 通 常 都 会 把 导航 栏 开 发 成 单 
独 的 一 个 页 面 ， 然 后 让 每 个 页 面 都 单独 调用 它 。 这 样 当 需要 变更 的 时 候 ， 只 要 修改 导航 栏 
这 一 个 负面， 其 他 的 页 面目 动 残 被 更 新 了 。 实 例 创 建 的 市 搜索 功能 的 导航 频道 ， 如 图 9-20 
所 示 。 
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图 9-20 ”搜索 导航 频道 


这 里 制作 的 步骤 如 下 。 
(1) 在 Dreamweaver CS 5.5 中 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 打开“ 新 建文 档 ” 对 


X99 PHP E AH ESAE 


话 框 ， 选 择 “ 室 白 页 ”选项 卡 中 “页 面 类 型 ”下 拉 列 表 框 中 的 PHP 选项 ， 在 “布局 ”下 拉 

列表 框 中 选择 “无 ”选项 ， 然 后 单 击 “ 创 建 ” 按钮 创建 新 页 面 ， 在 网 站 根 目录 下 新 建 一 个 名 

为 top.php 的 网 页 并 保存 。 | 
(2) 再 单 击 “ 显 示 代 码 视图 ”选择 [fa 掖 钮 ， 进 入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 G) 

创建 代码 删除 ， 然 后 加 入 如 下 代码 ; 


<?php 
session start(); 
include("conn/conn.php"); 
?>/ 调 用 session 函数 ， 并 调用 conn.php 数据 库 链 接 文件 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 电 子 商 务 网 站 </title> 
<link rel="stylesheet" type="text/css" href2"css/font.css"» 
</head> 
<body> 
<table width="766" border="0" align="center" cellpadding="0" cellspacing="0"  background- 
"images/bannerdi.gif"> 
<tr> 
<td colspan="3" valign="bottom"> «table width="766" border="0" align="center" cellpadding="0" 
cellspacing="0"> 
<tr> 
«td width="224" height="83">&nbsp; </td> 
<td align="right"> <p>&nbsp;</p> 
<table height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 
«form name="form" method="post" action="serchorder.php"> 
<tr> 
«td widthz" 81" height="30" align="right"> &nbsp;</td> 
<td widthz" "500" height-''30" valign='"''middle" ><div alignz"left'"» &nbsp;<span class="'style4"'> 
«img src="'images/biao.gif" width="16" height="21">&nbsp; 输 入 关键 词 : </span> 
«input type="text" name="name" sizez'25" class-z'inputcss" style="background-color:#e8f4ff " 
onMouseOver="'this.style.backgroundColor="#ffffff""" 
onMouseOut='" this.style.backgroundColor='#e8f4 伦 …> 
«input type="hidden" name="jdcz" value="jdcz"'> 
«input name-"'submit" type="submit" class-" buttoncss" value='"" 搜 索 "…> 
<input name-"'button" type-'button'" class-'"buttoncss" onClick-z"javascript:window.location- 
'highsearch. php';" value=" 高 级 搜索 "> 
</div> </td> 
</tr> 
</form> 
</table> </td> 
</tr> 
</table> </td> 
</tr> 
<tr> 
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— 


<td widthz"568" helght= 32"  bgcolorZ"*FFFFFF'»&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;«a href= 
"index.php"» H W «/a» &nbsp;| «a href="shownewpr.php"> 最 新 上 架 </a> | <a hrefz"showtuijian.php"» 
推荐 产品 </a> | «a hrefz"showhot.php"»2A1 ] j^ i </a> &nbsp;|&nbsp;«a href-"showfenlei.php"» ^ im 
4] 2S «la» &nbsp;|&nbsp;«a href="usercenter.php"> 用 户 中 心 </a>&nbsp;|&nbsp;<a href-"finddd.php"» 
订单 查询 </a>&nbsp;|&nbsp;<a href="gouwuche.php"> 购 物 车 </a></td> 
«td width="121" align="center" bgcolor="#FFFFFF"> 
<?php 
ifí$ SESSION([username]!2")( 
echo "用 户 :$_ SESSION[username DUGHIH fat" ; 
j 
2» 
</td> 
«td widthz" 77" bgcolorZ 4FFFFFF"*» 
<?php 
if($_SESSION[username]!=""){ 
echo "<a href='logout.php'> 注 销 离 开 </a>"; 
} 
7> 
</td> 
</tr> 
</table> 


上 述 代码 中 加 黑 部 分 为 搜索 功能 的 程序 。 | 
(D 加 入 代码 后 ， 就 会 发 现在 编辑 文档 窗口 中 ， 多 了 一 个 PHP 代码 占 位 符 W, 
如 图 9-21 所 示 。 


EE 


Ro TT TT PT DSYSDSUTUECUECUNESMPSUECUESGUMECUESUESUPSO DS) STO TX. 


ISSSSSSSASSASSSSASAAAAAAAAAAAASASAASA NAA SANA SANA SANA SANA AA NAA SANA SANA SANA AAA AAA AAA AAA ASA SA SANA AAA AAA SANA NN 


首 ”页 | EMER | 推荐 产品 | 热门 产品 | 产品 分 类 | 用 尸 中 心 | 订单 查询 | 购物 车 : pp Jug 


Soepssssssssssocssssccoccooscosssssssossesssssossooccoccoscesssscssssscsecscosseocecooccesossossssssessecossecceccecocssssssseccssccsseccccceccoccoccessossceseoesscsccsscooccccccccccceshoscsocoscecccecoccee 


图 9-21 HERRI EBERT 


最 后 保存 制作 的 页 面 ， 按 下 (F12) 快捷 键 ， 即 可 以 在 IE X aP ASARRE 
BUSCAR. 
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用 户 和 新 闻 显 示 


在 index.php 页 和 面 中 的 “产品 信息 ”栏目 里 面 ， 如 果 不 加 入 动态 功能 ， 则 只 能 显示 原来 
设计 的 静态 文字 。 如 果 想 调用 建立 的 shop 数据 库 中 “新 闻 表 ”里 面 的 新 闻 数 据 ， 并 且 能 够 
显示 最 新 的 10 条 信息 ， 如 何 用 PHP 进行 连接 和 处 理 呢 ? 

下 面 就 详细 介 绍 该 功能 的 开发 办 法 ， 制 作 步 又 如 下 。 

C1) 为 了 能 够 实现 页 面 的 调用 ， 需 要 首先 打开 数据 库 db shop 文件 ， 然 后 再 打开 
tb gonggao 数据 表 ， 加 入 一 些 数据 ， 如 图 9-22 Brzn. 


£ Table — [tb gonggao] — [db shop on localhost] 


Object ME A| | Fields | Indices | Triggers | Data |Description | DDL | 


HENCE. 


| [3 db shop on localhost [ Y 
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9-22 ”加 入 数据 


(2) 创建 left menu.php 页 面 ， 然 后 在 <head> 代 人 码 之 前 ， 加 入 调用 数据 库 连 接 页 面 
conn.php 的 如 下 命令 : 


<?php include("Conn/conn.php");?» 


加 入 后 简单 地 设计 一 下 用 户 系统 和 新 闻 公 告 两 个 功能 的 显示 效果 ， 设 计 完 成 后 编辑 文档 
窗口 ， 如 图 9-23 所 示 。 


T C: hpachevhtdaoesvshopAleft_merm. php (XHTML) 4Lx 


(R| 100% v568 x 347v 8 K / 1 秒 | 简体 中 文 6562312) 


9-23 设计 用 户 系统 和 新 闻 公 告 页 和 的 显示 效 采 


(3) 用 户 系 统 的 显示 界面 是 提供 给 用 户 登录 、 注 册 以 及 找 回 密码 的 功能 ， 具 体 的 注册 和 
找 回 密码 的 功能 将 在 下 一 市 介绍 ， 这 里 重点 介绍 使 用 PHP 实现 验证 人 码 随 机 调用 并 显示 为 数 
子 的 功能 程序 如 下 : 


<?php 
$num=intval(mt_rand(1000,9999)); 

/使 用 到 了 mt rand O 函数 调用 介 于 1000—9999 的 任意 一 个 数字 。 
for($i=0;$i<4;$i++){ 


echo "<img src=images/code/".substr(strval($num),$i,1).".gif>"; 


PHP+ 


} 
/调用 images/code/ 文 件 夹 下 的 随机 字母 图 乒 ， 并 显示 成 4 位 数 。 
iod RIP 
该 程序 能 够 实现 如 图 9-24 所 示 的 随机 显示 图 片 验 证 但 数字 BP: 
的 效果 。 - Ir 
(4) 用 户 输入 用 户 名 和 密码 ， 并 单 击 “提交 ”按钮 后 ， 要 将 Bum sm 
输入 的 数据 传递 到 chkuser.php 页 面 进行 登录 验证 。 
AR F: 图 9-24 显示 验证 码 效果 


«form name="form2" method="post" actionz"chkuser.php" onSubmit="return chkuserinput(this)"> 


说 明 : 

该 段 代码 包含 了 两 个 意思 ， 第 一 个 action="chkuser.php" 意 思 是 转 到 chkuserphp 页 面 进行 验 
证 ; 第 二 个 onSubmit="return chkuserinput(this)" 意 思 是 直接 调用 JavaScript 的 chkuserinput(this) 进 
行 数据 输入 的 验证 ， 即 通常 在 提交 表单 时 ， 要 验证 一 下 输入 的 数据 是 否 为 空 ， 输 入 的 数据 格 
式 是 否 符 合 要 求 。 调 用 的 程序 如 下 : 


<script language="JavaScript"> 
function chkuserinput(form){ 


"tt 


if(form.username.value--"")( 
alert(" 请 输入 用 户 名 !"); 
form.username.select(); 
return(false); 
} W 如 果 用 户 名 没 输入 ， 则 提示 “请 输入 用 户 名 ! ” 
if(form.userpwd.value--"")( 
alert(" 请 输入 用 户 密 人 码 !"); 


form.userpwd.select(); 


return(false); 
} W 如 果 用 户 密码 没 输入 ， 则 提示 “请 输入 用 户 密码 !” 
if(form.yz.value==""){ 

alert(" i555] A AEA 1"); 


form.yz.select(); 


return(false); 

} W 如 果 用 户 验 证 人 码 没 有 输入 ， 则 提示 “请 输入 验证 人 码 !1” 
return(true); 

} 
</script> 


(5) 在 主页 的 “新 闻 公 告 ”显示 的 数据 要 实现 的 效果 是 调 出 新 闻 的 标题 ， 在 单 击 标题 时 
能 打开 详细 页 面 ， 调 出 5 条 数据 。 下 面 将 所 有 的 代码 列 出 。 


<?php 

$sql=mysql_query("select * from tb_gonggao order by time desc limit 0,5",$conn); 
/按时 间 顺 序 从 tb_gonggao 数据 表 中 调用 5 条 数据 
$info=mysql_fetch_array($sq]); 
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if($info==false){ 

2 
<tr> 
«td height="20" align="center"> 暂 无 狐 闻 公告 1</td> 
</tr>// 如 果 没 有 数据 则 显示 为 “ 暂 无 狐 闻 公告 ! ” 
<?php 
j 
else{ 

do( 

2» 
<tr> 

<td height="20"><div align="center"> 

<table width="180" 

<tr> 
<td width="16" height="5"><div 
height="12"></div></td> 

<td width="164" height="24"><div 
$info[id];?>"> 

<?php 

echo substr(Sinfo[title],0,24); 

if(strlen(Sinfo[title])» 24) ( 
echo "..."; 


align="center"> «img 


align="left"> <a 


src-"images/circle.gif" 


href2"gonggao.php?id-«?php 


PHP 网 上 购物 系统 前 台 


border="0" align="center" cellpadding="0" cellspacing="0"> 


width="11" 


echo 


} /调用 新 闻 标 题 并 控制 显示 的 子 符 数 为 24， 如 果 标 题 比 较 长 则 显示 为 .… 


2» 
</a> </div></td> 
</tr> 
</table> 
</div></td> 
</tr> 
<?php 
j 
while(Sinfo2mysql fetch, array($sql)); 
j 


2» 


(6) 在 下 浏览 器 中 浏览 到 制作 的 调用 数据 的 结果 ， 
果 如 图 9-25 所 示 。 

in AH: 

如 此 轻易 就 实现 了 数据 库 的 调用 、 查 询 以 及 显示 操作 ， 读 者 会 
发 现 PHP 动态 网 页 的 开发 并 不 是 很 难 ， 只 需要 掌握 简单 的 代码 即 
可 以 实现 。 在 下 面 的 所 有 其 他 功能 区 域 都 是 采用 调用 、 条 件 查询 、 


基体 效 


绑 定 显示 、 关 闭 数据 库 这 样 一 个 相同 的 操作 步骤 来 实现 的 。 


一 


JA 
JA s 


网 站 实现 在 线 购物 ， 一 般 都 是 通过 用 户 上 自身 登录 、 浏 


| p = — Y 
产品 的 动态 展示 J 


用 户 系统 
RP: 
TH: 
验证 : 3541 
提 变 | 注册 找 回 密码 
新 闻 公告 : 更 多 


» 我 国 纸 业 三 大 热点 值得 关注 

» 用 办 公立 具 组 装 星 战 模型 

» 加 综 出 口 铝 笔 检验 监管 

» 中 国 低 碳 产 品 认证 局 动 

» 欧盟 纳米 材料 法 规 的 最 新 进 ... 


图 9-25 “最 新 新 闻 ” 的 效果 


订购 、 结 算 这 样 的 流程 来 实现 
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的 ， 所 以 在 首页 上 制作 产品 的 动态 展示 功能 非常 重要 。 实 例 在 首页 上 设计 了 “推荐 产品 ”、 
“最 新 上 架 ” 以 及 “热门 产品 ”3 个 显示 区 域 ， 下 和 面 束 介绍 产品 展示 区 域 的 实现 方法 。 

CD 对 于 上 述 的 3 个 显示 区 域 ， 在 使 用 程序 开发 之 前 ， 首 先 要 在 Dreamweaver CS 5.5 中 
设计 好 最 终 的 网 页 效果 。 实 例 设计 的 3 个 展示 区 域 如 图 9-26 所 示 ， 每 个 区 域 显 示 最 新 发 布 
的 两 球 产 品 信 息 ， 将 产品 的 图 片 、 价 格 、 数 量 全 部 展示 出 来 ， 并 加 入 “购买 ”和 显示 “ 评 
细 ” 的 按钮 。 


Tc:\Apache\htdocs\shop\indez. php (XHTML) -0x 


€ font.css top.php left menu.php bottom. php 


| 
pnp ii ^ 
F Es EAR nn: Bax. 


: 会 员 价 : Hg 


MRE 
N 
i 


[k] Q 100€ v788 x 550» 34 K / 1 秒 简体 中 交 (6B2312) 


图 9-26 设计 产品 展示 的 区 域 效 果 


(2) 3 个 区 域 的 程序 实现 的 方法 是 一 样 的 ， 只 是 按 条 件 碍 询 出 的 数据 结束 不 一 样 。 这 里 
介绍 “推荐 产品 ”区 域 的 代码 实现 方法 如 下 : 


«table widthz" 550" borderz"00" align="center" cellpaddingz" 0" cellspacing="0"> 
<tr> 
<td width="555" height="110"><table width="530" height="110" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
<tr> 
<td width="265"> 
<?php 

$sql=mysql_query("select * from tb_shangpin where tuijian=1 order by addtime desc limit 0,1");//Z 
tuijianz1 的 值 调用 数据 

$info=mysql_fetch_array($sql); 

if($info==false){ 

echo "本 站 暂 无 推荐 商品 !"; 

HM/ 如 果 没 有 数据 ， 则 显示 为 "本 站 和 暂 无 推荐 商品 

else{ 

2» 

«table width2"270" border= "0 cellspacing-" 0" cellpadding="0"> 


Ee E PHP E AH ESAE 


<tr> 
<td width="130" rowspan="5"><div align="center"> 
<?php 
if(trim($info[tupian]=="")){ 

echo " 暂 无 图 片 "; © 
MURRA mA MWERA AEA" 
else { 

2» 

«img src=" <?2php echo Sinfo[tupian];?»" widthz"80" height" 80" borderz"0"» 

<?php 
} 

2> 
</div> </td> 
«td width="11" height="16">&nbsp; </td> 
<td width="124"><font color="FF6501"> <img src-"images/circle.gif" widthz" 10" 
heightz"10"» &nbsp;«?php echo $info[mingcheng];?» </font> </td> 
</tr> 
<tr> 
«td height="16">&nbsp; </td> 
«td» «font color="#000000"> 市 场 价 :</font><font color="FF6501"><?php echo $info[shichangjia];?> 
</font> </td> 
</tr> 
<tr> 
«td heightz" 16" » &nbsp;«/td» 
«td» «font color="#000000"> 会 员 价 : </font><font colorZ"FF6501"»«?php echo S$info[huiyuanjia];?» 
</font> </td> 
</tr> 

<tr> 

«td heightz" 16" » &nbsp;«/td» 
«td» «font color='"#000000"> 剩 余数 量 : </font><font color2"13589B"» <?php 

if(Sinfo[shuliang]»O) 

{ 


echo $info[shuliang]; 
j 
else 
{ 
echo "已 售 完 ” 
} 
T> 
</font> </td> 
</tr> 
<tr> 
<td height="30" colspan="2"><a href="lookinfo.php?id=<?php echo $infoļ[id];?>"><img 
src="images/b3.gif" width="34" height="15" border="0"></a> «a href="addgouwuche.php?id=<?php 
echo $info[id];?>"><img src="images/b1.gif" width="50" height="15" border="0"></a> </td> 
</tr> 


L5 
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</table> 
<?php 
} 
je 
</td> 
«td widthz"265"» 
<?php 
$sql=mysql_query("select * from tb_shangpin where tuijian=1 order by addtime desc limit 1,1"); 
$info=mysql_fetch_array($sql); 
if($info==true) 
{ 
2» 
«table widthz"270" border="0" cellspacing-"0" celljpadding= "0 > 
<tr> 
<td width="130" rowspan="5"><div align="center"> 
<?php 
if(trim($info[tupian]=="")){ 
echo "和 暂 无 图 片 "; 
} 
else{ 
2» 
«img src=" «?php echo Sinfo[tupian];?»" width="80" heightz" 80" border="0"> 
<?php 
j 
2» 
</div> </td> 
<td width="11" height="16">&nbsp; </td> 
<td width="124"><font color="FF6501"> <img src-"images/circle.gif" widthz" 10" 
heightz" 10"» &nbsp;«?php echo $info[mingcheng];?» «X/font^ «/td* 
</tr> 
<tr> 
«td heightz"16"» &nbsp;«/td» 
«td» «font color="#000000"> 市 场 价 ;</font><font colorz"FF6501"» «?php echo Sinfo[shichangjia];?» 
</font> </td> 
</tr> 
<tr> 
«td height="16">&nbsp; </td> 
«td» «font color="#000000"> 会 员 价 : </font><font color="FF6501"><?php echo $info[huiyuanjia];?> 
</font> </td> 
</tr> 
<tr> 
«td height="16"> &nbsp;</td> 
«td» «font color="#000000" > 3é| 4x Zt 5g: </font><font color="13589B"> 
<?php 
if($info[shuliang]>0) 


echo Sinfo[shuliang]; 
j 
else 
{ 
echo "CE"; 
} 
?> 
</font> </td> 
</tr> 
<tr> 


<td height="30" | colspanz"2"»«a 


href="lookinfo.php?id=<?php 


【 PHP 网 上 购物 系统 前 台 


echo — S$info[id];?» "5 «img 


src-"images/b3.gif" widthz"34" height-"15" border="0"></a> «a href-"addgouwuche.php?id-«?php 
echo Sinfo[1d|;?» "5 «img src-"images/bl.gif" width="50" heightz" 15" borderz"0"» «/a» </td> 


</tr> 
</table> 
<?php 
j 
1S 
</td> 
</tr> 
</table> </td> 
</tr> 
<tr> 


«td height="10" background-z"images/linel.gif"» </td> 


</tr> 
</table> 


(3) 按 上 述 的 程序 实现 方法 ， 


果 如 图 9-27 所 示 。 


推荐 产品 : 


» 飞利浦 CORD 280 


A 市 场 价 : 145 
j x 会 员 价 : 100 
AA 剩余 数量 : 10 


[LEER | [>| 购 关 | 


» 兄弟 标签 打印 机 色 带 
市 场 价 : 155 
会 员 价 : 105 
剩余 数量 10 
[vf | |» | 3c 


热门 产品 : 


» 兄弟 标签 打印 机 色 带 
市 场 价 : 155 
会 员 价 : 105 


剩余 数量 : 10 


Tad 


[ER ) [» | 购买 ] 


将 万 外 两 个 产品 展示 的 功能 设计 完成 ， 最 后 可 以 实现 的 效 


更 多 . . 


» 办 公 桌 -01 
市 场 价 : 1200 
会 员 价 : 1000 
剩余 数量 : 10 
ER 


[ES ] | | nc 


» 飞利浦 CORD 280 

市 场 价 : 145 

会 员 价 : 100 

剩余 数量 : 10 
[E888 | |x| f 3c | 


» IAA- 
市 场 价 : 1200 
mýt: 1000 
剩余 数量 10 
EZALE 


图 9-27 首页 的 商品 展示 效果 
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Joo 底部 版 权 页 面 ) 


底部 版 权 页 面 是 一 个 静态 的 页 面 ， 制 作 非 音 简 单 。 在 Dreamweaver CS 5.5 中 进行 直接 排 
版 设计 即 可 ， 完 成 的 效果 如 图 9-28 PZR. 


HE] C: whpachevhtdocsvshopAbottom. php (XHTXL) -0X 


OR 
IMMSAASSASSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSASSSSSASASARASSSSSSSSSSSSSASASSSSSSSSSASSASSSSSSSSSSSSSSSSSSASSSSSSSASSSS SS 


(R| Q hoos [778 x 165v 1 K / 1 $5 fé febr (682312) 


图 9-28 版 权 页 面 的 设计 效 末 


以 上 网 站 的 首页 制作 全 部 结束 ， 如 宋 需 要 快速 建立 首页 ， 可 以 直接 参考 光盘 中 完成 的 页 
面 ， 碍 看 代码 ， 可 以 方便 地 完成 网 上 购物 系统 首页 的 设计 与 制作 。 


SUL ”会员 系 统 功能 


网 站 的 会 员 系 统 的 首页 可 以 让 用 户 完成 登录 或 注册 。 当 输入 用 户 名 和 密码 后 ， 单 击 “ 提 
六 ”按钮 ， 即 转 到 chkuser.php 页 和 面 进行 判断 是 否 成 功 登 录 。 当 单 击 “注册 ”文学 链接 时 ， 
将 会 打开 网 站 的 会 员 注 册页 面 agreereg.php 进行 注册 。 单 击 “ 找 回 密码 ”会 弹出 找 回 密码 的 
Windows 对 话 窗口 。 下 向 束 介 绍 会 员 系 统 的 开 友 方法 。 


SERLO 会 员 登 录 判 断 


会 员 在 首页 输入 用 户 名 和 密码 后 ， 单 击 “ 提 交 ” 按 钮 ， 只 有 用 户 名 、 密 码 、 验 证 码 全 部 
正确 才 可 以 登录 成 功 ， 如 末 发 生 错 误 就 需要 显示 相关 的 错误 信息 ， 所 有 的 功能 都 要 用 PHP 
进行 分 析 判 新。 创建 一 个 空白 PHP 页 面 ， 并 命名 为 chkuserphp。 

在 该 页 面 中 加 入 如 下 的 代码 : 


<?php 

include("conn/conn.php");// 调 用 数据 库 连接 

$username=$ POST[username]; 

$userpwd=md5($_ POST[userpwd]); 

$yz-$ POSTIyz]; 

$num-$ POST[num]; 

if(strval($yz)!2strval($num))( 
echo "«script^alert( WUEMA £8 TX V); history.go(- 1); /script? "; 
exit; 


MUREDE R, Mhen “WUEMA ENR!” . JP BOR IRIS DII 
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class chkinput{ 
var $name; 
var $pwd; 
function chkinput($x,$y){ ! 
$this->name=$x; > 
$this->pwd=$y; r 
j 
function checkinput()( 
include("conn/conn.php"); 
$sql2mysql query("select * from tb user where namez"" Sthis-» name." "",$conn); 
$info2mysql fetch, array($Ssql); 
if(Sinfo--false)( 
echo "<script language='javascript'>alert( 不 存在 些 用户 ! ";history.back();«/script^ "; 
exit; 
/如果 数据 库 里 不 存在 该 用 户 名 ， 则 显示 “不 存在 此 用 户 ”， 并 返回 
else{ 
if(Sinfo[dongjie]--1)( 
echo "<script language='javascript'>alert( 该 用户 已 经 被 冻结 ! ";history.back(); 


</script>"; 
exit; 
VH P Beeren fS, Mwea ZHP CARA! ”， 并 返回 
if($info[pwd]==$this->pwd) 
{ 
session start(); 
$ SESSION([username ]-S$info[name]; 
session register("producelist"); 
$producelist=""; 
session_register("quatity"); 
$quatity=""; 
header("location:index.php"); 
exit; 
j 


else ( 


echo "<script language- javascript» alert( IHA £8 V !. ;history.back(); «/script^ "; 
exit; 


M/ 如 果 用 户 密 人 码 错误 ， 则 显示 “密码 输入 错误 ! ”， 并 返回 


$obj=new chkinput(trim($username),trim($userpwd)); 
$obj-»checkinput(); 
7» 


该 段 程序 ， 首 先 判断 验证 码 、 用 户 名 以 及 密码 是 否 是 正确 的 代码 ， 如 果 不 正 确 ， 则 显示 
相应 的 错误 信息 ， 如 果 全 部 正确 ， 则 登录 成 功 并 返回 登录 的 首页 。 


TT 


9.4.2 会 员 注 册 功 能 


会 员 注 册 功 能 并 不 只 是 简单 的 一 个 网 页 束 能 实现 ， 它 需要 同意 协议 以 及 判断 用 户 是 人 否 已 
存在 ， 写 入 数据 等 细 蔬 步骤 如 下 。 

d) 早 击 “注册 ”文字 链接 时 ， 将 会 打开 网 站 的 会 员 注 册页 面 agreereg.php， 该 页面 制 
作 的 效果 如 图 9-29 所 示 。 访 页 面 的 内 容 是 必 不 可 少 的 ， 提 示 给 网 站 管理 员 ， 为 避免 日 后 与 
注册 用 户 发 生 纠 纷 ， 需 要 提前 将 网 站 所 提供 的 具体 服务 和 约束 等 内 容 ， 放 到 注册 信息 里 面 ， 
这 样 可 以 有 效 地 保护 目 己 的 利益 


TC: hlpackeVhidocslrhestagraerag. pho (EHTKEI = 


A iepbp leli mi lp em, php 


| ow UI TENER | NP. | NIFA | FROR | 用 户 中 心 [TAGEN | I i 39 ji 


L 司 | — — €—ÁP Pu(——Àa —— € NI 7709 
green 下 和 
TE P mem 

TEREA: 3 pes : i Roron [3 wai Elit aa dE a EENES: 

i | d I—— "T d H Sie. EB Pe pia HEEE ame ne 

Is umm — NM an Ha Arr S 站 BHE, TE 2 

War : nd 

gue MEME 

(tt 

ee 


中 


9-29 同意 网 站 里 的 服务 条 于 


(2) 单 击 “同意 ”按钮 后 ， 束 打开 具体 的 注册 用 户 信 息 填 写 内 容 页 。 该 页 面 制作 也 比较 
人 简单， 只 需要 以 数据 库 中 tb user 数据 表 的 字段 名 为 准 ， 在 注册 页 面 分 别 创 建 相应 的 文本 框 
即 可 ， 如 图 9-30 所 示 。 


T DCApackeVhtdoeslrhes se: pha (TETMLI -08 
ca bep.php leli mana php bolies. php 


——————m———————————————————————————— E 


banns AR E- a 


d 2.3 EAE ISTE | # Ara | PB lom LO ads | mess i gi E 


314 E2EALAFAEALALAEAREEILIEEEAILIEILILAET L-] 
-eari ma ea TT Mibtigenz? 0 


图 9-30 ”用户 填写 注册 信息 的 页 面 


G) 其 中 的 技术 难点 在 于 “得 看 昵称 是 售 已 用 ”功能 ， 在 输入 用 户 昵 称 时 ， 需 要 单 击 该 
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E 半 :后 玉 PHP 网 上 购物 系统 前 台 


按钮 ， 检 查 数 据 库 中 是 侍 已 存在 该 用 户 上 昵称 。 实 现 的 方法 代码 如 下 : 


<script language="JavasCript"> 
function chknc(nc) C 
| © 
windows.open("chkusernc.php?nc="+nc,"newframe","width=200,height=10,left=500,top=200,menubar= 这 
no,toolbar-no,location-no,scrollbars-no,location2no"); 
}/ 单 独 打 开 Windows 窗口 通过 调用 chkusernc.php 页 面 进行 判断 
</script> 


Br EHRCESRS SE ERAI N MÆ chkusernc.php, i LIBI a F : 


<?php 
$nc-trim($ GET[nc]); 
2» 
<?php 
include("conn/conn.php"); 
2> 
<html> 
<head> 
<title> 
昵称 重用 检测 
</title> 
<link rel="stylesheet" type="text/css" href="css/font.css"> 
</head> 
<body topmargin="0" leftmargin="0" bottommargin="0"> 
<table width="200" height="100" border="0" align="center" cellpadding="0" cellspacing="0" 
bgcolor="#eeeeee"> 
<tr> 
«td height="50"><div align="center"> 
<?php 
if($nc=="" 
{ 
echo "iei NETT; 
j 


else 


{ 


$sql=mysql_query("select * from tb user where name='".$nc. 


"ttt 


,Sconn); 
$info2mysgl fetch, array($sql); 

if($info—-true) 

{ 

echo "对 不 起 ,该 上 昵称 已 被 上 占用; 

} 

else 

{ 

echo "恭喜 ,该 昵称 没 被 占用 局 ; 
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j 
2» 
</div> </td> 
</tr> 
<tr> 
<td height="50"><div align="center"><input type="button" value=" fff 4E " class="buttoncss" 
onClick="window.close()"></div> </td> 


</tr> 
</table> 
</body> 
(4) 在 单 击 “提交 ”按钮 时 ， 还 要 实现 所 有 的 字段 检查 功能 ， 调 用 JavaScript 程序 进行 
检查 的 代码 如 下 : 


<script languagez" JavaScript"? 
function chkinput(form) 


{ 


if(form.usernc.value== 


{ 
alert(" 请 输入 昵称 !"); 
form.usernc.select(); 


"tt 


return(false); 

} 

if(form.p1.value=="") 

{ 
alert(" 请 输入 注册 密码 !"); 
form.pl.select(); 
return(false); 


j 


if(form.p2.value--"") 

{ 
alert(" 请 输入 人 确认 密码 !"); 
form.p2.select(); 
return(false); 


j 
if(form.pl.value.length«6) 


{ 

alert( "E HRB 1 BE NV XT. 6!"); 
form.pl.select(); 

return(false); 


j 


if(form.pl.value!-form.p2.value) 


{ 
alert(" 密 人 与 重复 密码 不 同 !"); 


form.pl.select(); 


return(false); 


} 
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if(form.email.value-- 
{ 
alert(" 请 输入 电子 邮箱 地 址 1"); 
form.email.select(); 
return(false); 


} 
if(form.email.value.indexOf( @')<0) 


{ 
alert(" 请 输入 正确 的 电子 邮箱 地 址 1"); 


form.email.select(); 


return(false); 
j 


if(form.tel.value-- 


{ 
alert(" 请 输入 联系 电话 !"); 


form.tel.select(); 


ntt 


return(false); 


j 


if(form.truename.value-z"") 
{ 
alert(" 请 输入 真实 姓名 !"); 
form.truename.select(); 
return(false); 


j 


if(form.sfzh.value-z"") 
{ 
alert(" 请 输入 身份 证 号 !"); 
form.sfzh.select(); 
return(false); 
} 
if(form.dizhi.value=="") 
{ 
alert( 2i 46i A Z& RE FEE!) 
form.dizhi.select(); 
return(false); 
j 
if(form.tsda.value-- 
{ 
alert(" 请 输 密 码 提示 答案 !"); 
form.tsda.select(); 


"tt 


return(false); 


} 
if((form.tsl.value==1)&&(form.ts2.value=="")) 

{ 

alert(" 请 选择 或 输入 密码 提示 答案 !"); 


form.ts2.select(); 
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return(false); 


j 


return(true); 


j 


</script> 


该 段 程序 是 验证 表 蛙 时 经 党 使 用 的 方法 ， 读 者 可 以 重点 浏览 并 掌握 其 功能 ， 在 其 他 系统 
的 开发 中 也 经 营 补 使 用 到 。 

(50 在 验证 表单 没 问 题 后 ， 才 将 衣 单 的 数据 传递 到 savereg.php 负面 进行 数据 表 的 插入 
记录 操作 ， 也 就 是 实质 上 的 保存 用 户 注 册 信息 的 操作 。 其 体 的 代码 如 下 : 


<?php 
session start(); 


include("conn/conn.php"); 
$name-$ POST[usernc]; 
$pwdl-$ POST[pl]; 
$pwd2md5($ POST[p1]); 
$email=$ POST[email]; 
$truename-$ POST[truename]; 
$sfzh-$  POST[sfzh]; 

$tel-$ POST[tel]; 
$qq=$_POST[qq]; 

if($ POSTI[ts1]==1) 


{ 
$tishi=$_ POSTIts2]; 
} 
else 
{ 
$tshi-$ POSTI[ts1]; 
} 


$huida=$ POSTI[tsdal: 
$dizhi=$_POST[dizhi]; 
$youbian=$_POST[yb]; 
$regtime-date(" Y -m-j"); 
$dongjie-0; 


111 min 


$sql=mysql_query("select * from tb user where name-"".$name.""",$conn); 
$info2mysql fetch, array(Ssql); 
if(Sinfo--true) 
{ 
echo "<script>alert( ZUG Ff CATE V);history.back(); «/script^ "; 
exit; 
j 


else 


{ 


mysql_query("insert into tb_user (name,pwd,dongjie,email,truename,sfzh,tel,qq,tishi,huida, 


dizhi,youbian,regtime,pwd1) values ('$name','$pwd','$dongjie','$email','’$truename','$sfzh','$tel', 
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'$gqgq','$tishi','$huida','$dizhi','$youbian','$regtime','$pwd1")",$conn);// 按 字段 对 应 相应 的 数据 
session register("username"); 
$username=$name: 
session register("producelist"); 全 


"tt, 


$producelist-""; 
session register("quatity"); 


$quatityz""; 
echo "&script^alertZ&2£, 3370] 9]! );window.location-'index.php'; «/script? "; 


HM/ 插入 数据 后 显示 注册 成 功 ， 并 返回 首页 index.php 
2» 
通过 以 上 几 个 步骤 的 程序 编写 才能 完成 一 个 会 员 注 册 的 功能 ， 
的 一 个 逻辑 实现 过 程 。 


找 回 密码 功能 P 


会 员 在 使 用 过 程 中 起 记 和 密码 也 是 经 常 过 到 的 事情 ， 在 实例 中 单 击 “ 找 回 密码 ”文子 链 


接 ， 将 打开 相应 的 窗口 实现 找 回 密码 的 功能 ， 其 体 的 实现 步 缀 如 下 。 
(1) 在 制作 的 left menu.php 页 面 中 加 入 JavaScript 的 验证 代码 ， 实 现 的 功能 是 单 击 “ 找 


加 密码 ”链接 时 ， 打 开 openfindpwd.php 页 面 进行 验证 ， 代 人 码 如 下 : 


"tt, 


般 的 会 员 注 册 都 是 这 样 


<script language="javascript"> 


function openfindpwd(){ 
windows.open("openfindpwd.php","newframe","left2200,top-200,widthz200,height-100,menubarzno, 


toolbar-no,location-no,scrollbars-no,location2no"); 


j 


</script> 


(2) 使 用 Dreamweaver 设计 出 找 回 密码 的 页 面 如 图 9-31 所 示 ， 只 需要 一 个 简单 的 对 话 
窗口 ， 输 入 昵称 并 进行 判断 即 可 。 


了 :ADachehtdcoeswshonwonentindnwda php -Dxx 


[&]éy Q 00$ [370 x Bv 3 K / 


图 9-31 找 回 密码 的 页 面 


(3) 在 输入 需要 找 回 密码 的 昵称 之 后 ， 单 击 “ 确 定 ”按钮 需要 进行 表单 验证 ， 判 断 是 否 
为 室 ， 如 果 不 为 空 则 指向 findpwd.php 页 面 显示 “密码 提示 ” 输入 提示 的 答案 ， 如 图 9-32 


ZR o 
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<script language-"javascript"? 
function chkinput(form) 
{ 


if(form.nc.value=="") 


{ 
alert(" 请 输入 您 的 昵称 !"); 
form.nc.select(); 


return(false); 


j 


return(true); 


j 


X/script 


T C: M pachekht does shopkfindpwi. php EXE 


PP TT TP PP aia E aiia 


hd 
[k]é9y Q 00$ vr x 131v 4 1 


图 9-32 ”密码 提示 页 面 


(4) 输入 “ 拓 示 管 采 ”之 后 ， 青 早 击 “确定 ”按钮 ， 也 要 进行 表 蛙 验证 ， 并 转 癌 最终 显 


a ABB UB showpwd.php， 验 证 的 代 公 如下: 


<script language="javascript"> 
function chkinput(form) 
{ 
if(form.da.value=="") 
{ 
alert( iei 48 AN ABERA RN; 
form.da.select(); 
return(false); 
j 
return(true); 


j 


</script> 


<form name="form2" method="post" action="showpwd.php" onSubmit="return chkinput(this)"> 


(5) showpwd.php 的 页 面 比 较 简 单 ， 只 需要 答 询 数据 库 ， 把 符合 条 件 的 数据 显示 出 来 ， 


即 把 昵称 和 密码 显示 在 页 面 上 即 可 ， 如 图 9-33 所 示 。 
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CApache ht does shonp'showpwd. php - Dx 


font. css conn. php 


9-33 最终 的 显示 密码 页 面 


Section 


新 闻 公 告 系 统 


网 站 的 “新 闻 公 告 ” 在 首页 及 各 个 页 面 显 示 标 题 ， 当 单 击 相应 的 标题 时 ， 打 开 详细 的 显 


示 内 容 页 面 gonggao.php。 与 网 站 的 新 闻 信 息 相关 的 页 面 ， 一 共有 2 个 ，gonggao.php HT Si 
示 具 体 的 信息 内 容 ， 另 一 个 是 用 于 单 击 首页 的 “更 多 >>” 文 字 链 按时， 打开 所 有 的 信息 标题 


页 面 的 gonggaolist.php. 


恒 鼠标 题 页 列表 


所 有 的 信息 标题 页 面 gonggaolist.php 制作 的 效果 如 图 9-34 所 示 。 


四 C:\Apache\htdocs\shop\EongEaolist. php (XHTML) 


. iara 
Se "— -———— ds 


3. .提交 注册 = É 


818 x 512v 17 K / 1 秒 简体 中 文 (582312) 


图 9-34 所 有 信息 标题 页 面 效 果 


L5 
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该 页 面 的 编号 程序 部 分 如 下 所 示 : 


<?php 
$sql=mysql_query("select count(*) as total from tb_gonggao",$conn); 
$info2mysql fetch, array(Ssql); 
$total-Sinfo[total]; 
if($total--0) 
{ 
echo "本 站 暂 无 公告 !"; 
HM/ 调 用 tb gonggao 数据 ， 如 果 没 有 则 显示 “本 站 和 暂 无 公告 !” 
else 
{ 
?> 
<table width="530" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr bgcolor="#EEEEEE"> 
<td width="296" height="20"><div align="center"> y 4 </div></td> 
<td width="136"><div align="center"> /z 4h] [8] </div></td> 
«td width="68"><div align="center"> Æ VJ &</div> </td> 
</tr> 
<?php 
$pagesize=20; 
if ($total<=$pagesize){ 
$pagecount=1; 
j 
if(($total% $pagesize)!=0){ 
$pagecount=intval($total/$pagesize)+1; 


Jelse( 
$pagecount-$total/Spagesize; 


} 
if(($_GET[page])==""){ 
$page=1; 
else { 
$page-intval($ GET[page]); 
j 


$sgll-mysql query("select * from tb gonggao order by time desc limit ".($page- 


I)*$pagesize.",Spagesize ",Sconn); 
while(Sinfol-mysql fetch array($sql1)) 
{ 
?> 
<tr> 
«td height="20"><div align="left">-<?php echo Sinfol[title];2» </div></td> 
«td height="20"><div align="center"> «?php echo $info1[time];?></div></td> 
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«td height-"20"*» «div alignz2"center'^«a href-"gonggao.php?id-«?php echo 
$infol[id]:?>"> 查 看 </a></div></td> 
</tr> 


| <?php - | 


2» 
<tr> 
<td height="20" colspan="3"> &nbsp; 
<div align="right"> 本 站 共有 公告 &nbsp: 
<?php 
echo $total; 
2» 
&nbsp; 4& &nbsp; $ H i zs &nbsp;«?php echo $pagesize;?»&nbsp; 条 &nbsp; 第 &nbsp;«?php echo 
$page;?»&nbsp; J1/J.: &nbsp;«?php echo $pagecount; ?» &nbsp; 页 
<?php 
if($page>=2) 
{ 
2» 

«a hrefz"gonggaolist.php?page-1" title" Pi W "><font face-"webdings"» 9 «/font»«/a» «a 
href-"gonggaolist.php?id-«?php echo $id;?» &amp;page-«?php echo $page-1;?»" title=" 亲 一 页 "><font 
facez"webdings"^ 7 </font></a> 

<?php 

j 
if($pagecount«-4)( 
for($i=1;$i<=$pagecount;$i++){ 
Is 
<a href=" gonggaolist.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php 
j 
}else{ 
for($i=1;$i<=4;$i++){ 
> 

«a href="gonggaolist.php?page=<?php echo $1;?» "5 «?php echo $1;?» «/a» 

<?php }?> 

«a href="gonggaolist.php?page=<?php echo $page-1;?>" title=" 后 一 页 "><font 
face="webdings"> 8 </font></a> «a href="gonggaolist.php?id=<?php echo $id;?>&amp;page=<?php 
echo $pagecount;?»" title=" }€ W "><font face="webdings"> : </font> </a> 

<?php }?> 

</div></td> 
</tr> 
</table> 
<?php 
j 


2» «/td» 
</tr> 
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</table> 


该 页 面 的 技术 难点 在 于 新 闻 标 题 的 分 页 显示 功能 ， 在 显示 的 标题 太 多 时 ， 一 般 部 要 使 用 
上 述 的 分 页 显示 功能 ， 实 现 按 页 显示 记录 。 


:SR 显示 详细 内 容 


具体 信息 量 显 示 页 面 ， 通 常 包 括 显 示 所 要 显示 信息 的 标题 、 时 则 以 及 出 处 ， 制 作 的 具体 
效果 如 图 9-35 所 示 。 


bc C:XApachehhtdocskshopigonggao. php (XHTML) - 口 X 


CRED top.php left menu php function.php bottom. php 


~ 
a 


~% 
^ 
SINT 
~ 


E is — E amamni 
E B a ~ 
:| 一 | 提交 | 注册 RATE > 


IGNASAAAANAAANAANANAAANAAAANANAAAAAAAAAAAAANANANAAE 1 
F JE 


Y E N 
MEE 
E: 


Po 


[km Q 100% v788 x 395v 15 K / 1 b. 简体 中 站 (GB2312) 


图 9-35 详细 新 闻 页 面 


该 页 面 的 编写 程序 部 分 如 下 所 示 : 


«table width2"530" border="0" align="center" cellpaddingz"0" cellspacing="1"> 
<?php 
$id-$ GET[id]; 
$sgl2mysql query("'select * from tb gonggao where id='".$id."",$conn); 
$info2mysgql fetch, array($sql); 
include("function.php"); 
lo 
<tr> 
«td width="24" height="25" bgcolor="#FFFFFF"> <div align="center"> </div> </td> 
<td width="315" bgcolor="#FFFFFF"><div align="center"> 公 f$; È  : <?php echo 
unhtml(Sinfo[title]);?» </div></td> 
«td width="66" bgcolor="#FFFFFF"><div align="center"> /z pl] [H]: </div></td> 
«td width="120" bgcolor="#FFFFFF"> «div align="left"><?php echo $info[time];?> </div></td> 
</tr> 
<tr> 
<td height="125" bgcolor="#FFFFFF"> <div align="center"></div></td> 
<td height="125" colspan="3" bgcolor="#FFFFFF"> <div align="left"> <?php echo 
unhtml(Sinfo[content]);?» </div></td> 
</tr> 
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</table> 
通过 上 述 两 个 页 面 的 设计 ， 新 闻 公 告 系统 的 前 人 台 部 分 即 开 发 完成 。 


Eee 产品 的 订购 功能 


购物 车 系统 主要 由 网 上 产品 订购 与 后 台 结 算 这 两 个 功能 组 成 ， 实 例 中 与 购物 车 相关 的 产 
品 显 示 的 页 面 就 包括 一 个 “购买 ”的 功能 按钮 。 其 中 主要 包括 index.php、 用 于 显示 产品 详细 
信息 的 页 面 lookinfo.php,“ 最 新 上 架 ” 频 道 页 面 Shownewprphp,“ 推 荐 产品 ”频道 页 面 
showtujjian.php,“ 热 门 产 品 ” 频 道 页 面 showhot.php,“ 产 品 分 类 ”频道 页 面 showfenlei.php、 
人 1 而 实现 的 功能 。 


9.6. 


产品 介绍 页 面 lookinfo.php 是 用 来 显示 商品 细节 的 页 面 。 细 节 页 面 要 能 显示 商品 所 有 的 
详细 信息 ， 包 括 丙 品 价 格 、 商 品 产地 、 商 品 单位 及 商品 向 片 等 ， 同 时 要 显示 是 售 还 有 剩余 产 
品 以 及 放 入 购物 车 等 功能 ， 实 例 还 加 入 了 “商品 评价 ” 

(OD 由 所 需要 建立 的 功能 出 发 ， 可 以 建立 如 图 9-36 所 示 的 动态 页 面 。 在 页 面 中 ，PHP 
代码 岁 标 代表 加 入 动态 命令 实现 该 功能 。 


5 C: hpachevht docsvshopvlookinfo. php (XHTML) - 口 X 


€» top.php  conn.php left menu. php bottom. php 


(20 该 模块 的 程序 分 析 如 下 ， 其 中 对 购物 车 的 订购 代码 进行 了 加 粗 说 明 : 


<?php 
$sql=mysql_query("select * from tb_shangpin where id=".$_GET[id]."",$conn); 


D 
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$info=mysql_fetch_object($sql); 
2> 
<tr> 
<td width="89" height="80" rowspan="4" align="center" valign="middle" bgcolor="#FFFFFF"> <div 
align="center"> 
<?php 
if($info->tupian==""){ 
echo "和 暂 无 图 片 "; 
} 
else 
{ 
I> 
<a href="<?php echo $info->tupian;?>" target="_blank"><img src="<?php echo $info->tupian;?>" 
at=" £r Zr X Kl" width="80" height="80" border="0"></a> 


<?php 
j 
2» 
</div> </td> 
<td width="92" height-"20" align="left" bgcolor="#FFFFFF"><div align="center"> 丙 品 名 称 : 
</div></td> 


<td width= 134" bgcolor= *FFFFFF"» «div alignz"left"» &nbsp;«?php echo $info- 
»mingcheng;?* «/div? </td> 

«td width" 100" bgcolor="#FFFFFF"><div align="center"> 入 市 时 间 : </div></td> 

«td widthz" 129" bgcolor= *FFFFFF"*» «div alignz"left"» &nbsp;«?php echo $info- 
>addtime;?></div> </td> 

</tr> 

<tr> 

«td height="20" align="left" bgcolor="#FFFFFF"><div align="center"> 会 员 价 : </div></td> 

«td widthz" 134" bgcolor= *FFFFFF"» «div alignz"left"» &nbsp;«?php echo $info- 
>huiyuanjia;?> </div> </td> 

«td width="100" bgcolor="#FFFFFF"><div align="center"> TH: </div></td> 

«td width= 129" bgcolor= *FFFFFF"*» «div alignz"left"» &nbsp;«?php echo $info- 
»shichangjia;?» </div></td> 

</tr> 

<tr> 

«td height="20" align="left" bgcolor="#FFFFFF"><div align="center"> 等 级 : </div></td> 

«td widthz" 134" bgcolor= *FFFFFF"» «div alignz"left"» &nbsp;«?php echo $info- 
»dengji;?» </div> </td> 

«td width="100" bgcolor="#FFFFFF"><div align="center"> 品 牌 : </div></td> 

<td Width= 129" bsgcolor= *FFFFFF"* «div align-z"left"» &nbsp;«?php echo $info- 
»pinpai;?» </div></td> 

</tr> 

<tr> 

«td height="20" align="left" bgcolor="#FFFFFF"><div align2"center" 5713575; </div></td> 

«td widthz" 134" bgcolor= *FFFFFF"» «div alignz"left"» &nbsp;«?php echo $info- 
»xinghao;?*» «/div* </td> 
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«td width="100" bgcolor="#FFFFFF"><div align="center"> 数 量 : </div></td> 

«td width-" 129" bsgcolor= *FFFFFF"'* «div align="left"> &nbsp;«?php echo $info- 
>shuliang;?></div> </td> 

</tr> - 
<tr> ©) 
<td width="89" height="69" bgcolor="#FFFFFF"><div align="center"> H m faj: </div></td> 

«td height="69" colspan="4" bgcolor="#FFFFFF" valign="top"> «div align="left"><br> 
&nbsp;&nbsp;&nbsp;&nbsp;<?php echo $info->jianjie;?> </div></td> 

</tr> 

</table> </td> 

</tr> 

</table> 

<table width="530" height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 

<tr> 

«td» «div align="right"><a href="addgouwuche.php?id=<?php echo $info->id;?>"> 放 入 购物 车 </a> 
&znbsp;&nbsp;</div></td>1/ 单 击 “ 放 入 购物 车 ”传递 产品 的 Id 号 并 到 addgouwuche.php 去 结算 

</tr> 


</table> 
<?php 
if($_SESSION[username]!="") 
{ 
2» 
<form  name-"forml" method="post" action-"savepj.php?id-«?php ^ echo $info->id;?>" 


onSubmit-"return chkinput(this)"? 
«table widthz"530" borderz"0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
«td height="25" bgcolor="#EEEEEE"> <div align="center" style="color: #FFFFFF"> 
<div align="left"> &nbsp;&nbsp;«span style="color: #000000"> 发 表 评 论 </span></div> 
</div> </td> 
</tr> 
<tr> 
<td height="150" bgcolor="#999999"><table width="530" border="0" align="center" 
cellpadding="0" cellspacing="1"> 
<script language="javascript"> 
function chkinput(form) 


if(form.title.value=="") 
{ 
alert(" 请 输入 评论 主题 !"); 
form.title.select(); 
return(false); 
j 
if(form.content. value-- 
{ 
alert(" 请 输入 评论 内 容 !"); 
form.content.select(); 


"tt 


PHP+ 


return(false); 


j 


return(true); 


</script> 
<tr> 

<td width="80" height="25" bgcolor="#FFFFFF"><div align="center"> YE ie 3i: </div></td> 
<td width="467" bgcolor="#FFFFFF"> <div align="left"> 
<input type="text" name="title" size="30" class="inputcss" style="background-color:#e8f4ff 
onMouseOver="this.style.backgroundColor='#ffffff" 
onMouseOut="this.style.backgroundColor='#e8f4ff "> 
</div></td> 
</tr> 
<tr> 
«td height="125" bgcolor="#FFFFFF"><div align="center"> Eie AZ: </div></td> 
«td height="125" bgcolor="#FFFFFF"> <div align="left"> 
<textarea name="content" cols="70" rows="10" class="inputcss" style="background-color:#e8f4ff " 
onMouseOver="this.style.backgroundColor='#ffffff" 
onMouseOut="this.style.backgroundColor='#e8f4ff "> </textarea> 
</div></td> 
</tr> 
</table></td> 

</tr> 
</table> 

<table width="530" height="25" border="0" align="center" cellpadding="0" cellspacing="0"> 

<tr> 


" 


<td><div align="center"> 

<input name="submit2" type="submit" class="buttoncss" value=" RK "> 

&nbsp;&nbsp;&nbsp;<a href="showpl.php?id=<?php echo $ GET[id]?»"» 查看 该 商品 评论 
</a> </div></td> 

</tr> 

</table> 

</form> 

<?php 

} 


?> 


(3) 在 上 面 的 代码 中 ， 产 品 的 展示 只 是 数据 的 查询 及 显示 的 功能 ， 核 心 在 于 “发 表 评 
论 ” 在 单 击 “ 发 表 ” 按 钮 时 是 传递 到 savepj.php 页 面 保存 评价 的 ， 其 页 面 的 代码 如 下 : 


<?php 
include("conn/conn.php"); 
$title-$ POST[title]; 
$content-$ POST [content]; 
$spid-$ GET[id]; 
$time-date(" Y -m-j"); 
session start(); 
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min 


$sql=mysql_query("select * from tb user where name-2".$ SESSION[username].""",Sconn); 
$info2mysql fetch array($sql); 

Suserid-Sinfo[id]; 

mysql query("insert into tb pingjia (userid,spid,title,content,time) values 
('Suserid', Sspid','Stitle','Scontent','Stime") ",Sconn); >D 


echo "<script>alert(" 评 论 发 表 成 功 !);history.backOj;</script>"; 


?> 


最 新 上 架 频 道 


单 击 导 航 条 中 的 “最 新 上 架 ” 链 接 到 页 面 Shownewprphp， 访 页 面 主要 是 显示 数据 库 中 
最 新 上 架 的 商品 。 
CD 首先 ， 完 成 静态 页 面 的 设计 ， 访 页 面 完 成 后 的 效果 如 图 9737 PTR. 


C: A pacheXhtdocsVshopishownewpr. php (XHTML) -Bx 


HIRED top.php left menu.php bottom. php 


100% ”v788 x 391v 18 K / 1 $6 简体 中 交 (GB2312) - 


图 9-37 最 刹 上 染 的 静态 页 面 效 果 
(20 代码 主要 核心 部 分 如 下 所 未: 


«table width="550" height="70" borderz"0" align="center" cellpadding-"0" cellspacingz"0"» 
<?php 
$sql=mysql_query("select * from tb_shangpin order by addtime desc limit 0,4",$conn); 
/从 产品 表 中 调 出 最 新 加 入 的 4 条 产品 信息 
$info=mysql_fetch_array($sql); 
if($info==false){ 
echo "本 站 和 暂 无 最 新 产品 !"; 
} 
else{ 
do{ 
2> 
<tr> 
«td width="89"rowspan="6"><div align="center"> 
<?php 


* 


网 站 建设 从 入 门 到 精通 


if(Sinfo[tupian]22" )( 
echo " 暂 无 图 片 !"; 
} 
else{ 
fo: 
«a  href-"lookinfo.php?id-«?php echo $infoļid];?>"><img border="0" | src-"«?php echo 
$info[tupian];?»" width" 80" height="80"></a> 
<?php 
} 
le: 
</div></td> 
«td width="93" height="20"><div align="center" style="color: #000000"> 疝 品名 称 : </div></td> 
<td colspanz"5"» «div align="left"><a href="lookinfo.php?id=<?php echo $info[id]:?>"><?php echo 
$info[mingcheng];?» «/a» </div></td> 
</tr> 
«tr? 
«td width="93" height-"20"» «div align="center" style="color: 4000000" » rj i: </div></td> 
«td widthz2" 101" height-"20"*» «div alignz"left"» «?php echo S$info[pinpai];?» «/div5 </td> 
«td widthz"62"» «div align="center" style="color: 4000000" » rj mA! y: </div></td> 
«td colspanz"3"* «div alignz"left"» «?php echo S$info[xinghao];?» «/div» </td> 
</tr> 
<tr> 
«td width="93" height="20"><div align="center" style="color: #000000"> 商 品 人 简介 : </div></td> 
«td height="20" colspan="5"><div align="left"><?php echo $infoļ[jianjie];?> </div></td> 
</tr> 
<tr> 
«td height="20"><div align="center" style="color: 4000000"» ET H #H: </div></td> 
«td height="20"><div align="left"><?php echo $infoļaddtime];?></div> </td> 
«td height="20"><div align="center" style="color: #000000"> 剩 余数 量 : </div></td> 
«td width="69" height="20"><div align="left"><?php echo $info[shuliang];?> </div></td> 
<td width="63"><div align="center" style="color: #000000"> 了 商品 等 级 : </div></td> 
«td width="73"><div align="left"><?php echo $info[dengji];?> </div> </td> 
</tr> 
<tr> 
«td height="20"><div align="center" style="color: 4000000" » RM: </div></td> 
«td height="20"><div align="left"><?php echo $info[shichangjia];?> 元 </div> </td> 
«td height="20"><div align="center" style="color: 4000000" n: </div></td> 
«td height="20"><div align="left"><?php echo $info[huiyuanjia];?> 7G €/div? </td> 
«td height="20"><div align="center" style="color: #000000"> 折 扣 : </div></td> 
<td height="20"><div align="left"><?php echo (@ceil(($info[huiyuanjia]/$info[shichangjia])*100)). 
"%";?></div></td> 
</tr> 
<tr> 
<td height="20" colspan="6" width="461"><div align="center"> &nbsp;&nbsp;&nbsp;&nbsp;«a 
href="addgouwuche.php?id=<?php echo $infoļ[id];?>"><img src="images/b1.gif" width="50" 
height="15" border="0" style=" cursor:hand"></a></div> </td> 


$95 QUuNMSIEUXI 


</tr> 
<tr> 
«td height="10" colspan="7" background="images/line1.g1f"></td> 
</tr> 
<?php 
)while(Sinfo2mysql fetch array(S$sql)); 
j 
2 
</table> 


9.6.3 Hn 1B 


产品 ”链接 到 页 面 showtujjian.php， 访 页面 主要 是 显示 数据 库 中 
推荐 的 商品 。 
(D 首先 ， 完 成 静态 页 面 的 设计 ， 该 页面 完成 后 的 效果 如 图 9-38 所 示 。 


E] C: \Apachethtdocs\shop\showtui jian. php (XHTML) - 口 X 


HIRED top. php left menu.php bottom. php m 
^ 


搜索 | uem 


TS Q 1008  . T88 x 391v 20 /1 秒 简体 中 交 (6B2312) — 


图 9-38 ”推荐 产品 的 静态 页 面 效果 
(20 推荐 产品 的 功能 和 最 刹 上 染 频 道 功能 基本 上 一 样 ， 不 同 的 地 方 在 于 推荐 时 从 数据 库 


但 询 的 代码 不 一 样 ， 主 要 核心 的 不 同 部 分 如 下 所 示 : 


<?php 

$sql=mysql_query("select count(*) as total from tb_shangpin where tuijian=1 ",$conn); 
/从 tb_shangpin 数据 表 中 查询 出 tuijian=1 的 商品 

$info=mysql_fetch_array($sq]); 

$total=$info[total]; 

if($total==0) 


{ 
echo "本 站 暂 无 推荐 产品 !"; 
} 
else 
{ 


?> 


PHP*MySQL-*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


enero 执 门 产品 频道 

单 击 导航 条 中 的 “热门 产品 
门 的 丙 品 。 

Gd) 首先 ， 完 成 静态 页 面 的 设计 ， 该 页面 完成 后 的 效果 如 图 9-39 所 示 。 


四 C:\Apache\htdocs\shop\showhot. php (XHTML) 


”链接 到 页 面 showhot.php， 该 页 面 主要 是 显示 数据 库 中 热 


HIRED top.php left menu.php bottom. php 


图 9-39 热门 产品 的 静态 页 面 效 果 


(20 热门 产品 的 功能 主要 核心 不 同 部 分 如 下 所 示 : 
<?php 
$sql=mysql_query("select * from tb_shangpin order by cishu desc limit 0,10",$conn); 
// 从 tb. shangpin 数据 表 中 查询 出 10 条 的 热门 产品 
$info2mysgql fetch, array($sqL); 
if(Sinfo--false) 
{ 
echo "本 站 和 暂 无 热门 产品 !"; 
j 
else 


{ 
do 


i 


2» 


905 产品 分 类 频道 


单 击 导航 条 中 的 “热门 产品 
同 的 商品 。 


(o 首先 ， 完 成 静态 页 面 的 设计 ， 访 页面 完 成 后 的 效 末 如 图 9-40 所 示 。 


”链接 到 页 面 showfenlei.php， 访 页面 按 商品 的 分 类 显示 不 


Ts 


\PHP 网 上 购物 系统 前 台 


Jd 电子 商务 网 站 = Nicrosoft Internet Explorer DAR 
TFT AEE 查看 0) KRA IAT) $5B500 r7 


QAE- O- NAGAR wx O 2- a BL 
地 址 (0) |Æ] http: //127.0.0. 1/shop/showfenlei. php 所 输入 关键 词 搜索 pra 链接 Snan E 


PHP 电 子 商 务 网 站 Q a xw: 


首页 | 最 新 上 架 | 推荐 产品 | 热门 产品 | 产品 分 类 | 用 户 中心 | 订单 查询 | 购物 车 
HAR DARM 办 公设 备 办 公用 纸 办 公文 具 
本 类 商品 > 办公 息 档 


商品 型 号 : adtian001 
| XB RBS 
ie 3X | 注册 找 回 密码 : 2011-6-1 剩余 数量 : 10 
会 员 价 : 1000 元 
SR : SE» 


» 我 国 纸 业 三 大 热点 值得 关注 nen —— 
» 用 办 公立 上 组装 星 战 模型 z: : SEXE IDE 
» 加强 出 口 铝 笔 检验 嵌 管 : 2011-6-1 PRAE: 10 
» 中国 低 碳 产品 认证 启动 : 1600 元 会 员 价 ; 1200 元 
» 欧盟 纳米 材料 法 规 的 最 新 进 ， 
本 站 共有 该 类 商品 2 件 每 页 显示 3 件 第 1 页 / 共 1 页 1 


All CopyRights reserved 2011 环 博 文化 


D Internet 
9-40 分 关 的 静态 页 面 效 末 
(20 分 类 的 功能 主要 核心 不 同 部 分 如 下 所 示 : 

<?php 

if($ GET[id]2-"") 

{ 

$sql=mysql_query("select * from tb_type order by id desc limit 0,1",$conn); 

// 从 tb type 数据 表 中 查询 出 所 有 的 商品 分 类 


$info-mysgql fetch, array($sql); 
$id-Sinfo[id]; 


j 


else 
{ 
$id=$_GET[id]; 
j 
$sql12mysgql. query("select * from tb type where id-".S$id."",$ conn); 
$infol2mysgql fetch array(S$sgl1); 


$sql2mysql query('select count(*) as total from tb shangpin where typeid-"".$id." order by 
addtime desc ",$conn); 


$info-mysql fetch  array(S$sql); 
S$total-Sinfo[total]; 
if($total==0) 

{ 


echo "<div align='center> 本 站 暂 无 该 类 产品 !</div>"; 


else 


一 般 的 大 型 网 站 都 没有 搜索 功能 ， 在 首页 中 要 设置 商品 搜索 功能 。 输 入 搜索 的 商品 名 
称 ， 单 击 搜 索 按钮 后 ， 要 打开 的 页 耐 束 是 这 个 商品 搜索 结果 页 面 serchorderphp。 
(1)〉 由 上 面 的 功能 分 析出 发 ， 设 计 好 的 丙 品 搜索 结果 页 面 如 图 9-41 所 示 。 


5 C: NApache\htdocs\shop\serchorder. php (XHTML) -0x 


conn. php  top.php left_menu. php bottom. php 


简体 中 交 (GB2312) — 


9-41 产品 搜索 结果 页 面 


(2) 相关 的 程序 代码 分 析 如 下 : 


<?php 
$jdcz=$_POST[jdcz]; 
$name-$ POST[name]; 
$mh-$ POST[mh]; 
$dx-$ POST[dx]; 
if($dx=="1"){ 
$dx=">"; 

} 

elseif($dx=="-1"){ 

$dx-2"«"; 
} 

else{ 

$dx="="; 
} 
$jg=intval($_POST[jg]); 
$Ib-$ POSTY[Ib]; 

if($jdcz!=""){ 


X959 PHP E AH ESAE 


$sql=mysql_query ("select * from tb shangpin where mingcheng like '%".$name."%' order by addtime 
desc", $conn);//144) 2S 44 EAE] tb. shangpin 数据 表 
j 


else 

| D 
if($mh=="1"){ 

$sql=mysql_query("select * from tb shangpin where huiyuanjia $dx".$jg." and typelid=".$lb.” and 
mingcheng like '%".$name."%'",$conn); 

]/ 按 会 员 价 查 询 tb. shangpin 数据 表 

else{ 

$sql2mysql query("select * from tb shangpin where huiyuanjia $dx".$jg." and typeid-"".$Ib." and 


11111 


mingcheng = "".$name.""",$conn); 
j 
j 
$info2mysql fetch, array(S$sql); 
if(Sinfo--false)( 
echo "<script language-'javascript »alert( Z&» Pf J52S [D P^ im !);history.go(-1);/script? "; 
j 
else( 
ie: 
«table widthz"530" borderz"0" align="center" cellpaddingz"0" cellspacingz" 1" bgcolorZ' 4CCCCCC"» 
«tr bgcolor="#FOFOFO"> 
«td width='"92" heightz"25"» «div align="center" style="color: 4990000" » 44 f «/div» «/td» 
«td widthz"83"» «div align="center" style="color: 4990000" » m fH «/div» «/td» 
«td widthz"62"» «div align="center" style="color: 4990000" » 1H </div></td> 
«td widthz"62"» «div align="center" style="color: 4990000" » 4 fà ffr «/div» «/td» 
«td widthz"161"» «div align="center" style="color: 4990000"» 上 市 时 间 </div></td> 
«td widthz"48"*» «div align="center" style="color: #FFFFFF"> <span class="style1"></span> </div></td> 
«td width="42"><div align="center" style="color: 4990000" > f&F«/div» </td> 
</tr> 
<?php 
do( 
2» 
«tr bgcolorZ 4 FFFFFF"*» 
«td height2"25"*» «div align="center" > «?php echo $info[mingcheng];2></div></td> 
«td height2"25"*» «div alignz"center"» «?php echo Sinfo[pinpai ];?» </div> </td> 
«td height2"25"» «div align-"center"» «?php echo Sinfo[shichangjia];?» X/div^ </td> 
«td heightz2"25"» «div alignz"center"» «?php echo Sinfo[huiyuanjia];?» </div></td> 
«td height2"25"*» «div align="center" > «?php echo S$info[addtime];?» </div></td> 
<td height2"25"»«div align-"center'»«a href-"lookinfo.php?id-«?php echo $info[id]:?>"> fr 看 
X/a» </div> </td> 
«td heightz"25"»«div align="center"><a href="addgouwuche.php?id=<?php echo $info[id];?>"> 购 物 
</a> </div></td> 
</tr> 
<?php 
}while($info=mysql_fetch_array($sq1)); 
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j 


2» 
</table></td> 
</tr> 

</table> 


到 这 里 ， 就 完成 了 与 商品 相关 动态 页面 的 设计 ， 可 以 实现 网 站 产品 的 前 台 展 示 和 订购 
的 功能 。 


Section 


9.7 ”网 站 的 结算 功能 


网 站 的 核心 技术 ， 就 在 于 产品 的 展示 与 网 上 订购 、 结 算 功能 ， 在 网 站 建设 中 这 部 分 知识 
统称 为 “购物 车 系统 ”。 购 物 车 最 实用 的 功能 就 是 可 进行 产品 结算 ， 通 过 这 个 功能 ， 用 户 在 
选择 了 自己 喜欢 的 产品 后 ， 可 以 通过 网 站 确认 所 需要 的 产品 ， 输 入 联系 方式 ， 提 交 后 写 入 数 
据 库 ， 方 便 网 站 管理 员 进 行 售后 服务 ， 这 也 就 是 购物 车 的 主要 功能 。 


*NAES 订单 的 统计 


addgouwuche.php 页 面 在 前 面 的 代码 中 经 常用 到 ， 束 是 单 击 “购买 ”图 标 按钮 后 ， 需 要 调用 
的 页 面 ， 主 要 是 实现 统计 订单 数量 的 功能 页 面 。 该 页 面 完全 是 PHP 代码 ， 如 图 9-42 所 示 。 
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9-42  addgouwuche.php 页 面 的 设计 


代码 分 析 如 下 : 


<?php 
session start(); 


SQL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 
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include("conn/conn.php"); 
if($_SESSION[username]==""){ 
echo "<script>alert( 请 和 完 登录 后 购物 !");history.back(;</script>"; 
exit; 
}/ 判 断 是 否 已 经 登录 
$id=strval($_GET[id]); 
$sql=mysql_query("select * from tb shangpin where id='".$id."",$conn); 


$info2mysql fetch, array(Ssql); 
if(Sinfo[shuliang]«-0)( 
echo "&script»alert(Z A imi OCGA 56 !);history.back(); «/script? "; 
exit; 
HM/ 判 断 是 否 还 有 产品 
$array=explode("@",$_SESSION[producelist]): 
for($i=0;$i<count($array)-1;$i++){ 
if($array[$i]==$id){ 
echo "<gscript>alert(' 该 商品 已 经 在 您 的 购物 车 中 !);history.backO:;</script>";/ 判 断 是 合 重 复 购 买 


exit; 


} 
$_SESSION[producelist]=$_SESSION[producelist].$id."@"; 


$_SESSION[quatity]=$_SESSION[quatity]."1 @"; 
header("location:gouwuche.php");// 实 现 统 计 累 加 的 功能 并 进行 转 问 
d» 


说 明 : 

session 是 在 PHP 编程 技术 中 ， 占 有 非常 重要 份量 的 函数 。 由 于 网 页 是 一 种 无 状态 的 链 
接 程 序 ， 因 此 无 法 得 知 用 户 的 浏览 状态 。 必 须 通 过 session 变量 记录 用 户 的 有 关 信 息 ， 供 用 
户 再 次 以 此 身份 对 服务 器 提出 要 求 时 做 出 确认 。 


清空 订 曲 


在 购物 车 订购 过 程 中 ， 通 过 单 击 “删除 ”或 “清空 购物 车 ”文字 链接 ， 能 够 调用 
removegwc.php 页 面 ， 通 过 里 面 的 命令 清空 购物 车 中 的 数据 统计 ， 设 计 的 PHP 代码 如 图 9-43 
所 示 。 

清除 订单 的 代码 如 下 : 


<?php 

session start(); 

$id-$ GET[id]; 

$arraysp-explode(" 9 ",$ SESSION[producelist]); 

$Sarrayslzexplode(" 9 ",$ SESSION[quatity]); 

for($120;$i«count(Sarraysp);$i--4-) ( 
if(Sarraysp[$i]--$1d)( 


"M, 


$arraysp[$i]=""; 


PHP-MySQL-*Dreamweaver 35:5 AH 
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9-43 removegwc.php Ji [ftl 


"tt, 


$arraysl[$i]=""; 
j 
j 
$ SESSION[producelist]-implode(" Q ",Sarraysp); 
$ SESSION[quatity |-implode(" Q ",Sarraysl); 
header("location:gouwuche.php"); 
ro: 


通过 上 面 的 命令 可 以 清空 购物 车 里 的 订单 ， 并 返回 gouwuche.php 重 痢 进行 订购 。 


9 79 购物 车 信息 


用 户 登 录 后 选择 商品 放 入 购物 车， 单 击 首页 上 的 “去 收银 合 ” 文 学 链接 ， 则 打开 订单 用 户 信 息 
确认 页 面 gouwusuan.php， 在 该 页 面 中 需要 输入 收 贷 人 的 详细 信息 ， 设 置 的 结 末 如 图 9-44 所 不。 
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9-44 订单 确认 页 面 
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| 生成 订单 
单 击 “提交 订单 ”按钮 后 ， 则 调用 savedd.php 页 面 。 访 页面 的 功能 是 把 订单 写 入 数据 c 
库 后 返回 gouwusuan.php iig, Hd n: ' 


<?php 
session start(); 


include("conn/conn.php"); 


min 


$sql=mysql_query("select * from tb user where name-"".$ SESSION[username].""",$conn); 
$info2mysgl fetch, array($sql); 
$dingdanhao-date(" Y mjHis").Sinfo[id]; 
$spc-$ SESSION[producelist]; 

$slc= $ SESSION[quatity]; 
$shouhuoren-$ POST[name2]; 

$sex-$ POST[sex]; 

$dizhi-$. POST[dz]; 

$youbian-$ POST[yb]; 

$tel-$ POST[tel]; 

$email-$ POST[email]; 

$shff=$ POST[shff]; 

$zfff-$ POST[zfff]; 

if(trim($_ POST[lyp--"")( 


"M, 
, 


$Sleaveword- 


} 
else{ 
$leaveword-$ POSTI[ly]; 

} 

$xiadanren=$_SESSION[username]; 

$time=date("Y-m-j H:i:s"); 

$zt=" 未 作 任何 处 理 "; 

$total=$ SESSION[total]; 

mysql query('insert into tb dingdan(dingdanhao,spc,slc,shouhuoren,sex,dizhi,youbian,tel,email,shff, 
Zfff,leaveword,time,xiadanren,zttotal) values ($dingdanhao', $spc','$slc', Sshouhuoren', $sex',' $dizhi',' $youbian', 
'Stel','Semail','Sshff','Szfff,'Sleaveword','Stime', $xiadanren','$zt','Stotal')",Sconn); 

header("location:gouwusuan.php?dingdanhao-S$dingdanhao"); 
2» 


| 订单 查询 ) 


用 户 在 购物 的 时 候 ， 还 需要 知道 自己 在 近期 一 共 购 买 了 多 少 商 品 。 单 击 导航 条 上 的 “ 订 
单 查询 ”命令 ， 打 开 查 询 输入 的 页 面 finddd.php， 在 查询 文本 域 中 输入 客户 的 订单 编号 或 者 
下 订单 人 姓名 ， 都 可 以 查 到 订单 的 处 理 情况 ， 方 便 与 网 站 管理 员 的 沟通 。 订 单 查 询 功 能 和 首 
页 上 的 商品 搜索 功能 设计 方法 是 一 样 的 ， 需 要 在 输入 的 查询 页 面 设置 好 连接 库 的 连接 ， 设 置 


" 


QL+Dreamweaver 动态 网站 建设 从 入 门 到 精通 


PHP+ 


查询 输入 文本 域 ， 建 并 查询 命令 。 具 体 的 设计 分 析 同 前 面 的 搜索 功能 模块 设计 相同 ， 完 成 的 
效果 如 图 9-45 所 示 。 


T C: MipachelhtdoesVshopVfinddd php (XHTML) - 口 X 


top.php left menu.php  bottom.php Y 
^ 


a 
IOIOIOIOIOIOISrorer 
31 


voles roro roro boo. 


MEDIATE Smm NE 


| 注册 找 回 密码 : 


LI 
MMESARAARAARAARAARAARAARSAARSAARAARSAARSAROTeI 


< 
(body [RI T69 x 394v 19 K / 1 秒 | 简体 中 文 (5B2312) 


图 9-45 订单 查询 页 面 效 果 


通过 本 草 的 介绍 ， 整 个 购物 系统 网 站 前 台 的 动态 功能 的 核心 部 分 痢 已 经 介绍 完 ， 其 他 一 
些小 功能 页 面 这 里 惑 不 做 具体 的 介绍 ， 用 户 在 使 用 时 ， 可 以 根据 目 己 的 需求 对 网 站 进行 一 定 
的 完善 和 更 改 ， 达 到 目 己 的 使 用 要 求 。 


c NE ga PHuPIOVIAEUSGTE 


一 个 完善 的 网 上 购物 系统 不 仅 要 提供 给 用 户 注册 、 购 物 的 功能 ， 它 还 要 提供 给 网 站 所 有 
者 一 个 功能 齐全 的 后 合 管理 功能 ， 例 如 ， 网 站 所 有 者 登录 后 合 即 可 进行 发 布 新 公告 、 会 员 注 
册 管 理 、 回 复 留 言 、 商 品 维护 ， 以 及 订单 的 管理 。 本 章 主要 介绍 使 用 PHP 进行 网 上 购物 系 
统 后 台 开 发 的 方法 。 


MATIE A 


本 草 主要 掌握 以 下 知识 点 : 


O 购物 系统 后 台 的 架构 设计 
(7 后 台 登 录 的 商品 管理 功能 
(7 RARAP EHAE 
(7 后 台 的 订单 管理 功能 
(7 后 人 台 的 信息 管理 功能 


PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


后 台 的 架构 设计 


购物 车 后 台 管 理 系统 是 整个 网 站 建设 的 难点 ， 它 包括 了 几乎 所 有 的 利用 PHP 处 理 技术 ， 实 
例 的 后 合 主要 要 实现 “商品 管理 ^“ 用 户 管理 “订单 管理 ^“ 信 息 管 理 ”4 大 功能 模块 。 和 网 
站 前 台 的 制作 方法 一 样 ， 在 进行 具体 的 功能 开发 之 前 ， 肯 和 完 要 进行 一 个 后 台 的 需求 整体 规划 。 


O 后 台 整体 规划 


本 实例 将 所 有 制作 的 后 台 管 理 页 面 放置 在 admin 文件 夹 下 ， 和 单独 设计 一 个 网 站 一 样 ， 
需要 建立 一 些 音 用 的 文件 夹 ， 如 用 于 连接 数据 库 的 文件 夹 conn、 用 于 放置 网 页 样式 表 的 文件 
F css， 放 置 图 片 的 文件 夹 imnages， 以 及 用 于 放置 上 传 产品 图 片 的 文件 夹 upimages。 设 计 完 
成 的 整体 文件 夹 及 文件 如 图 10-1 所 示 。 
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10-1 网 站 后 台 文 件 结构 
mE V N Z —^ 
对 需要 设计 的 页 面 功能 分 析 如 表 10-1 所 示 。 
表 10-1 购物 系统 后 台 页 面 功能 分 析 
网 站 后 台 文 件 主要 功能 
addgonggao.php 增加 新 公告 的 页 面 
addgoods.php 增加 商品 信息 的 页 面 
addleibie.php 增加 商品 类 别 的 页 面 
admingonggao.php 增加 商品 公告 的 页 面 
changeadmin.php 管理 员 信息 变更 页 面 
changegoods.php 商品 信息 变更 页 面 
changeleaveword.php 会 员 留 言 变 更 页 面 
chkadmin.php 管理 员 登 录 验 证 页 面 


网 站 后 台 文 件 
conn/conn.php 
default.php 
deleted.php 
deletefxhw.php 
deletegonggao.php 
deletelb.php 
deleteleaveword.php 
deletepingjia.php 
deleteuser.php 
dongjieuser.php 
editgonggao.php 
editgoods.php 
editleaveword.php 
editpinglun.php 
edituser.php 
finddd.php 
function.php 
index.php 
left.php 
lookdd.php 
lookleaveword.php 
lookpinglun.php 
lookuserinfo.php 
orderdd.php 
saveaddleibie.php 
savechangeadmin.php 
savechangegoods.php 
saveeditgonggao.php 
savenewgonggao.php 
savenewgoods.php 
saveorder.php 
showdd.php 
showleibie.php 


top.php 


从 上 和 面 的 分 析 统 计 看 到 该 网 站 后 


ISTF A fn]. 


登录 管 
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主要 功能 
数据 库 连 接 文件 页 面 


后 合 登 录 后 的 首页 E 
删除 订单 的 页 面 


VE 


删除 商品 评论 页 面 
删除 用 户 信息 页 面 
冻结 用 户 处 理 页 面 
编辑 公告 内 容 页 面 
编辑 商品 信息 页 面 
编辑 用 户 留 言 页 面 
编辑 用 户 评 论 页 面 
编辑 用 户 信息 页 面 
订单 查询 页 面 
调用 的 常用 函数 
后 从 用 户 登 录 
展开 式 树 状 导 航 条 
查看 订单 页 面 
RAH AA RM 
查看 用 户 评论 页 面 
但 看 用 户 信 息 页 面 
执行 订单 页 面 
保存 新 增 商 品 大 类 页 面 
保存 用 户 信 息 变 更 页 面 
保存 经 修改 商品 信息 
保存 经 修改 公告 内 容 
保存 新 增 公 告 信息 
保存 新 增 公 告 信息 
保存 执行 订单 页 面 
打印 订单 的 功能 页 面 
商品 大 类 显示 页 面 
台 管 理 的 顶部 文件 


台 总 共 由 42 个 页 面 组 成 ， 从 开发 的 难 易 度 来 看 并 不 比 


后 台 的 功能 开发 和 网 站 的 前 台 功 能 开发 并 个 大 一 样 ， 前 台 除 了 功能 的 需求 之 外 ， 还 十 
讲究 更 多 的 网 页 布局 即 网 站 的 美工 设计 ， 后 台 的 开发 则 主要 重视 功能 的 需求 开发 ， 而 网 页 


7PHP-^ 


工 可 以 放 到 其 次 ， 因 为 使 用 后 台 的 丈 古 网 站 所 有 者 那么 一 两 个 人 。 本 小 节 将 介绍 网 站 后 台 从 
登录 到 可 实现 的 定理 具体 有 哪些 流程 ， 以 方便 读者 更 容易 了 解 后 面 小 市 的 内 容 。 

CD 对 于 网 站 所 有 者 需要 登录 后 台 进 行 网 上 购物 系统 的 管理 ， 由 于 涉及 很 多 商业 机 密 ， 
所 以 需要 设计 登录 用 户 确 认 页 面 ， 通 过 和 输入 唯一 的 用 户 名 和 密 码 来 登录 后 侣 进行 管理 。 本 网 
上 购物 系统 为 了 方便 使 用 ， 只 需要 在 首页 用 户 系 统 中 直接 输 入 “用 户 名 ”(admin) fI "E 


但 ”(admin)， 登 录 的 地 址 为 : http://127.0.0.1/shop/admin/login.php， 如 图 10-2 所 示 。 
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图 10-2 后 台 管 理 登 录 页 面 


(2) 单 击 “ 登 录 ” 按 钮 即 可 以 登录 后 台 的 首页 进行 全 方位 的 管理 ， 如 网 10-3 所 示 。 
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10-3 “后台 管理 主 界面 


(3) 单 击 左边 树 状 管 理 菜单 中 的 “商品 管理 ”， 可 以 展开 包含 “增加 商品 入 “修改 商 
品 和 “类 别管 理 ^“ 添 加 类 别 ”4 个 功能 荣 单 项 ， 通 过 这 4 个 功能 ， 主 要 实现 商品 的 添加 、 
修改 管理 。 如 图 10-4 所 示 为 增加 商品 页 面 。 
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10-4 增加 商品 页 面 


(40 如 果 想 实现 对 用 户 的 害 理 ， 可 以 单 击 “ 用 户 管理 ”展开 式 亲 单 ， 里 而 包括 了 “会 员 
管理 人 “留言 管理 ”， 以 及 “更 改 管理 员 ”3 个 菜单 项 ， 在 这 3 个 功能 中 ， 后 台 管 理 者 不 但 可 
以 实现 对 注册 会 员 的 删除 管理 ， 还 可 以 实现 相应 留言 的 删除 管理 ， 对 于 后 台 登 录 的 admin 4 
份 也 可 以 进行 变更 。 如 几 10-5 所 示 为 后 台 管 理 者 变更 页 面 。 
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图 10-5 后 台 管 理 者 变更 页 面 


(50 订单 管理 是 购物 系统 后 台 管理 的 核心 部 分 ， 单 击 “ 订 单 管理 ”展开 式 末 单项 ， 可 以 
看 到 包括 了 “编辑 订单 ” "n “AWIE” WARE. KPRI FUSE SCOHUBU tU PW 
单 后 与 管理 员 进 行 交 互 ， 管 理 员 需 要 及 时 处 理 订 单 ， 并 进行 发 货 方 要 完成 的 购物 交易 的 环 
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10-6 编辑 订单 页 面 


(6) 单 击 “信息 管理 ”展开 式 菜 单 ， 其 中 包括 了 “管理 公告 “发 布 公告 ”以 及 “管理 
评价 ”3 个 功能 。 通 过 这 3 个 功能 ， 外 PT E^ pod sh E BE SEE P Id. e E ELE T n 
评论 的 编辑 修改 功能 ， 如 图 10-7 所 示 。 
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107 ”管理 公告 页 面 


上 述 的 后 台 管 理 系统 从 登录 到 各 功能 的 管理 页 面 来 看 ， 后 人 台 管 理 功能 非常 流畅 ， 能 够 捉 
供 非 常 便利 的 网 站 管理 后 台 前 提 是 需要 网 站 设计 者 与 管理 员 沟 通 到 位 ， 问 清 需求 后 ， 方 可 规 
划 出 实用 的 网 站 后 台 。 


"USES 后 台 登 录 的 设计 


一 般 后 台 管 理 员 在 进行 后 台 管 理 时 都 需要 先进 行 身 份 验证 。 实 例 用 于 登录 的 页 面 如 
图 10-8 所 示 ， 在 单 击 “ 登 录 ” 按 钮 后 ， 确 认 后 人 台 登 录 管 理 身 份 的 动态 文件 为 chkadmin.php。 
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【PHP 网 上 购物 系统 后 台 开 


四 C: \Apacheihtdocs\shopiadminilogin. php -0x 


EIAS 


Eam font. css 


R] Q 100$ v769 x 394v 4 K / 1 b 简体 中 文 (GB2312)  - 


图 10-8 后 台 管 理 员 登录 静态 效果 


(1) 该 页 面 制作 比较 简单 ， 主 要 的 功能 代码 如 下 : 


<script language-" JavaScript"> 


function chkinput(form)( 
if(form.name.value--"")( 

alert(" 请 输入 用 户 名 !"); 
form.name.select(); 
return(false); 

j 

if(form.pwd.value--"")( 
alert( i548] NH] J m R3 1"); 


form.pwd.select(); 


return(false); 
} 
return(true); 

}]/ 单 击 登 录 按 钮 进行 表单 的 验证 
</script> 


<form name-"form1" method="post" action="chkadmin.php" onSubmit="return chkinput(this)">// 通 过 
验证 后 ， 转 到 chkadmin.php 进行 判断 


(2) chkadmin.php 是 判断 管理 员 吴 份 是 否 正 确 的 页 面 ， 使 用 PHP 编写 的 程序 如 下 : 


<?php 
class chkinput{ 
var $name; 
var $pwd; 
function chkinput($x,$y) 
{ 
$this->name=$x; 
$this->pwd=$y; 
} 


function checkinput() 


{ 


PHP 


include("conn/conn.php"); 


$sgl2mysql. query("select * from tb admin where name=".$this->name."",$conn);// 从 数据 表 tb. admin 
调 出 数据 

$info=mysql_fetch_array($sq]); 

if($info==false) 


{ 
echo "<script language='javascript'>alert(' 不 存在 此 管理 员 ! );history.back(); «/script^ "; 
exit; 
]/ 如 果 不 存 在 ， 则 显示 为 “不 存在 此 管理 员 ” 
else 
{ 


if($info[pwd]==$this->pwd){ 
header("location:default.php"); 
}/ 如 果 正 确 ， 则 登录 default.php W H 


else 
echo "<script language=javascript>alert( 密 但 输入 错误 ! );history.backO;</script> "; 
exit; 
j 


$obj2new chkinput(trim($ POST[name ),md5(trim($ POST[pwd]))); 
$obj-^»checkinput(); 


?> 


O| 树 状 菜单 的 设计 


后 人 台 管 理 的 导航 全 单 是 一 个 树 状 的 展开 式 荣 单 ， 分 为 二 级 某 单 ， 在 单 击 一 级 某 单 时 可 以 
实现 二 级 菜单 的 展开 和 合并 的 操作 ， 在 Dreamweaver 中 设计 的 样式 如 图 10-9 所 示 。 


b C: XÀApachekhtdocshshopkadminkleft. php - 口 X 


Y 


Ps font. css 
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而 实现 动态 的 展开 和 合并 是 使 用 JavaScript 实现 的 ， 核 心 的 代码 如 下 : 


<script ljanguage= JavaScript > 


function openspgl(O( 
if(document.all.spgl.style.displayz-"none")[ > | 


document.all.spgl.style.display= 
document.all.d 1 .src="images/point3. gif"; 
j 
else( 
document.all.spgl.style.displayz"none"; 
document.all.d1.src-"images/pointl.gif"; 


j 


j 
function openyhgl()[ 
ifí(document.all.yhgl.style.display2-"none")( 
document.all.yhgl.style.display-z""; 
document.all.d2.src-2"images/point3.gif"; 
j 
else{ 
document.all.yhgl.style.display= none ; 


document.all.d2.src="images/point1.g1f"; 


j 


j 


function openddgl()1 
ifí(document.all.ddgl.style.display2-"none")( 
document.all.ddgl.style.display-z""; 
document.all.d3.srcz"images/point3.gif"; 
j 
else{ 
document.all.ddgl.style.display="none"; 


document.all.d3.src="images/point1.g1f"; 


j 


j 


function opengggl(){ 
ifí(document.all.ggegl.style.display2-"none")( 
document.all.gggl.style.displayz""; 
document.all.d4.src-"images/point3.gif"; 
} 
else{ 
document.all.gggl.style.display="none"; 


document.all.d4.src="images/point1.gif"; 


j 
j 


</script> 
PIRR EAH TAA, wen up ARRAPA A, Bom 
Pd x5 BB tr EH. 
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根据 需求 ， 商 品 管理 功能 页 面包 括 了 增加 商品 Caddgoods.php). fU Ceditgoods.php)s 
2S JI E Cshowleibie.php). WINA] Caddleibie.php) 4 个 功能 页 面 。 本 小 和 残 介 绍 这 几 个 
前 品 管理 功能 页 面 程序 实现 方法 。 


在 前 台 展 示 的 所 有 产品 都 是 从 后 台 进 行商 品 发 布 的 ， 供 商品 发 布 的 学 段 要 与 数据 库 中 保 
存 商品 的 设计 宰 段 一 一 对 应 。 实 例 所 设计 的 增加 商品 静态 页 面 addgoods.php 效果 如 图 10-10 
所 示 。 


T) C: XApacheXht docsshopiadminkaddgoods. php cmo 


am ma FI FI FI FI E I I I RII I Po 0 0 0 n n n no no n no no no no no no no n n n n n n n ex CX CX CX CX CX ex ex er 


ome me me mi mi mi mi mi me mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi R PU PI mi PII FI mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi m me m m mom 
body> Kr) 769 x 394v 8 K / 1 $5 WAPE 2312) 


10-10 增加 商品 的 静态 页 面 效 果 
(1 ) addgoods.php 的 程序 核心 代码 如 下 : 


<script language=" JavaScript"> 
function chkinput(form) 
if(form.mingcheng.value=="") 
alert(" 请 输入 商品 名 称 !"); 
form.mingcheng.select(); 
return(false); 
j 
if(form.huiyuanjia.value2-"") 
{ 
alert(" 请 输入 商品 会 员 价 !"); 
form.huiyuanjia.select(); 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


省 | 二 请 汉 PHP 网 上 购物 系统 后 台 开 发 


return(false); 
j 
if(form.shichangjia.value-z"") 
{ i 
alert(" 请 输入 商品 市 场 价 !"); Ə 
form.shichangjia.select(); 
return(false); 
j 
if(form.dengji.value--"") 
{ 


alert(" 请 输入 商品 等 级 !"); 
form.dengji.select(); 
return(false); 
} 
if(form.pinpai.value=="") 
{ 
alert(" 请 输入 商品 品牌 !"); 
form.pinpai.select(); 


return(false); 


j 


if(form.xinghao.value--"") 
{ 
alert(" 请 输入 商品 型 号 !"); 
form.xinghao.select(); 
return(false); 


j 


if(form.shuliang.value-z"") 


{ 
alert(" WFA F8] mA"); 
form.shuliang.select(); 


return(false); 


j 


if(form.jianjie.value—- 


{ 


"tt 


alert(" 请 输入 商品 简介!"); 
form.jianjie.select(); 
return(false); 


j 


return(true); 


</script>// 进 行 表 单 验 证 
«form name="form1" enctype="multipart/form-data" method="post" action="savenewgoods.php" 
onSubmit="return chkinput(this)">// 验 证 后 提交 savenewgoods.php 页 面 进行 处 理 


(2) savenewgoods.php 是 实现 将 发 布 的 商品 信息 保存 到 数据 库 的 文件 ， 代 人 码 如 下 : 


<?php 
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include("conn/conn.php"); 


if(is numeric($ POST[shichangjia])--false || is numeric($ POST[huiyuanjia])—-false) 


{ 
echo "<script>alert(' 价 格 只 能 为 数字 ! ";history.backO;«/script^ "; 
exit; 
} 
if(is numeric($ POST[shuliang])==false) 
{ 
echo "<script>alert( 数 量 只 能 为 数学 ! ';history.back();</script>"; 
exit; 
} 
$mingcheng-$ POST[mingcheng]; 
$nian=$ POST[nian]; 
$yue-$ POST[yue]; 
$ri=$ POST[ri]; 
$shichangjia-$ POST[shichangjia]; 
$huiyuanjia-$ POST[huiyuanjia]; 
$typeid-$ POST[typeid]; 
$dengji-$ POST[dengji]; 
$xinghao-$ POST[xinghao]; 
$pinpai-$ POST[pinpai]; 
$tuijian-$ POSTY[tuijian]; 
$shuliang-$  POST[shuliang]; 
$upfile-$ POST[upfile]; 
if(ceil(($huiyuanjia/$shichangjia)* 100)«280) 
{ 
$tejia=1; 
} 
else 
{ 
$tejia=0; 
} 
function getname($exname)( 
$dir = "upimages/";// 列 出 产品 图 片 的 上 传 目 录 
$i=1; 
if(lis_dir($dir)){ 
mkdir($dir,0777); 
} 
while(true){ 
if(lis_file($dir.$1.".".$exname)){ 
$name=$1i.".".$exname:; 
break; 


j 
$i++; 
j 


return $dir.$name; 
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} 
$exname=strtolower(substr($_FILES['upfile'][name'],(strrpos($_FILES['upfile'][name'],.)+1))); 
$uploadfile = getname(Sexname); 


move. uploaded file($ FILES['upfile']|'tmp name'], Suploadfile); NI 
if(trim($ FILES['upfile']| name']!2"")) © 
{ "m 
$uploadfile-"admin/".$uploadfile; * 
} 
else 
{ 
$uploadfile=""; 
} 


$jianjie=$_POST[jianjie]; 


$addtime=$nian."-".$yue."-".$ri; 

mysql_query("insert into tb_shangpin(mingcheng,jianjie,addtime,dengji,xinghao,tupian,typeid,shichangjia, 
huiyuanjia,pinpai,tuijian,shuliang,cishu)values('$mingcheng','$jianjie', '$addtime','$dengji','$xinghao','$upl 
oadfile','$typeid','$shichangjia','$huiyuanjia','$pinpai','$tuijian','$shuliang','0')",$conn); 

echo "<script>alert(' R ii " .$mingcheng." 75372] !);window.location.href='addgoods.php';</script>"; 
?>/ 上传 成 功 转向 addgoods.php 页 面 


上 述 PHP 的 程序 编写 中 ， 核 心 在 于 产品 图 片 的 上 传 功能 。 
eR 修改 商品 功能 


在 商品 发 布 后 ， 如 果 发 现 发 布 的 商品 信息 有 错误 ， 可 以 通过 单 击 “ 修 改 商品 ”功能 来 进 
行商 品 信息 的 调整 。 在 后 台中 单 击 “ 修 改 商 品 ” 打开 的 是 editgoods.php WH. 


(1) 使 用 Dreamweaver 制作 的 静态 页 面 效 果 如 图 10-11 所 示 。 


四 C:\Apache\htdocs\shop\admin\editEoods. php = CX 


CALD font.css conn. php 
g 
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图 10-11 修改 商品 静态 页 面 效 采 


(2) 在 该 页 面 中 可 以 单 击 “ 复 选 ” 复 选 按钮 ， 再 单 击 “ 删 除 选项 ”按钮 实现 商品 删除 的 
操作 ， 链 接 到 deletefxhw.php 进行 删除 操作 。deletefxhw.php 是 从 数据 库 中 删除 该 商品 信息 ， 
使 用 的 代码 如 下 : 


<?php 
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include("conn/conn.php"); 
while(list($name,$value)zeach($ POST)) 
{ 
$sql=mysql_query("select tupian from tb_shangpin where id="".$value.""",$conn); 
$info=mysql_fetch_array($sql); 
if($info[tupian]!="") 
{ 
@unlink(substr($info[tupian],6,(strlen($info[tupian])-6))); 
j 
$sgli2mysql. query("select * from tb dingdan ",$conn); 
while(Sinfol-mysql fetch array($sql1)) 
{ $idl-Sinfol [id]; 
$array-explode(" Q ",Sinfol[spc]); 
for($120;Si«count(Sarray);$i--4-) ( 
if(Sarray[$i1]--$ value) 


{ 
mysql_query("delete from tb dingdan where 1d="".$1d1."",$conn); 
j 
j 
j 
mysql query("delete from tb shangpin where id- ".$value.""",Sconn); 
mysql query("delete from tb pingjia where spid="".$value.""",$conn); 
j 
header("location:editgoods.php"); 
?> 


(3) 通过 单 击 “ 更 改 ” 文 字 链 接 能 打开 changegoods.php 页 面 进行 商品 的 信息 变更 ， 该 


页 面 设计 的 样式 和 添加 产品 时 的 样式 是 一 样 的 ， 如 图 10-12 所 示 。 


b C: SApache*ht docsSshop*adminkchangegoods. php -0x 


€i font.css conn. php 
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图 10-12 商品 的 信息 变更 页 面 


(4) 在 编辑 商品 信息 之 后 ， 单 击 “ 更 改 ” 按 钮 提交 表单 到 savechangegoods.php 页 面 进 
行 数据 库 的 更 新 操作 ， 核 心 代码 如 下 : 


+10% GUIES 


<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 

<?php 

include("conn/conn.php"); 

$mingcheng-$ POST[mingcheng]; 
$nian=$ POST[nian]; © 
$yue-$ POST[yue]; 

$ri=$ POST[ri]; 

$shichangjia-$ POST[shichangjia]; 

$huiyuanjia-$ POST[huiyuanjia]; 

$typeid-$ POST[typeid]; 

$dengji-$. POST[dengji]; 

$xinghao-$ POST[xinghao]; 

$pinpai-$  POST[pinpai]; 

$tuijian-$. POST[tuijian]; 

$shuliang-$ POST[shuliang]; 

//Supfile-$ POST[upfile]; 


if(ceil(($huiyuanjia/Sshichangjia)* 100) «280) 
{ 
$tejia=1; 
j 
else 
{ 
$tejia=0; 
j 
if(Supfile!-"") 
{ 
$sql=mysql_query("select * from tb_shangpin where 1d=".$_GETI[id]."",$conn); 
$info2mysgql fetch, array($sql); 
(à unlink(substr(S$info[tupian],6,(strlen(Sinfo[tupian])-6))); 
j 


function getname($exname)( 
$dir 2 "upimages/"; 
$i=1; 
if(lis_dir($dir)){ 
mkdir($dir,0777); 


while(true)( 
if('is file($dir.$1.".".Sexname))( 
$name-$i.".".Sexname; 
break; 

} 


$i++; 
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return $dir.$name; 


S$exname-strtolower(substr($ FILES ['upfile']| name'],(strrpos($. FILES['upfile'][ name'],'.)--1))); 
$uploadfile = getname(Sexname); 

move. uploaded file($ FILES['upfile']|'tmp name'], Suploadfile); 

$uploadfile-"admin/".$uploadfile; 

$jianjgie-$ POST[jianjie]; 

$addtime-$nian."-".$yue."-".$ri; 

mysql. query(" update tb shangpin set 
mingcheng-' $mingcheng'jianjie-' $jianjie',addtime-'$addtime',dengji-'$dengji',xinghao-' $xinghao',tupia 
n-'$uploadfile',typeid- Stypeid',shichangjia-'$shichangjia',huiyuanjia- $huiyuanjia',pinpai- $Spinpai',tuiji 
an-'$tuijian',shuliang-' $shuliang' where id-".$. GET[id]." ",Sconn); 
echo "«script»alert( Ñ ia ".$mingcheng. f P VJ] V); history .back0;;«/script» "; 
T> 


更 新 数据 库 主要 应 用 到 了 update 这 个 数据 库 更 新 命令 。 


10.2.3 MBR n1) RE ) 


商品 的 类 别提 供 了 删除 功能 ， 通 过 单 击 “操作 ” 复 选 按钮 再 单 击 “ 删 除 选 项 ” 即 可 以 将 
类 别 从 数据 库 中 删除 。 访 功能 首页 为 showleibie.php。 

(1) 使 用 Dreamweaver 设计 的 该 页 面 的 静态 效果 如 图 10-13 所 示 。 访 页面 主要 实现 从 类 
列 的 数据 表 中 得 询 出 相应 的 数据 绑 定 到 该 页 面 。 


T C: pacheWhtdoesVshop Va dninVshowl eibi e. php SAE 
L 
CHRED font.css conn. php Y 
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图 10-13 MRJ R r 


(2) 单 击 选择 相应 的 类 列 复 选 按 钮 ， 再 日 击 “ 删 除 选 项 ”， PEKAR] deletelb.php 动态 
页 面 进 行 删 除 。 在 删除 时 ， 要 把 相关 联 的 商品 信息 也 一 并 删除 ， 即 通过 商品 的 ID 同时 删除 
tb type 和 tb_shangpin。 实 现 删 除 类 别 的 代码 如 下 : 


<?php 
include("conn/conn.php"); 
while(list($name,$value)=each($_POST)){ 
mysql_query("delete from tb type where id=".$value.”"",$conn);// 删 除 类 别 
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mysql_query("delete from tb_shangpin where id=".$value."",$conn);// 删 除 类 别 下 的 商品 
} 
header("location:showleibie.php");// 删 除 成 功 ， 则 转 问 showleibie.php 页 面 

2» 


添加 类 别 功能 es 


电子 商务 网 站 的 商品 是 多 种 多 样 的 ， 在 后 全 要 设置 商品 分 类 的 功能 。 在 实际 的 网 站 开发 
中 经 名 有 一 级 分 类 、 二 级 分 类 ， 甚 全 三 级 分 类 都 有 ， 这 些 还 涉及 来 单 的 二 级 联动 问题 。 本 实 
例 只 建立 了 一 级 分 类 ， 管 理 员 可 以 在 后 台 直 接 添 加 一 级 的 分 类 ， 谎 加 类别 功能 的 主页 面 是 
addleibie.php. 

(1) 使 用 Dreamweaver 设计 addleibie.php 页 面 的 静态 效果 如 图 10-14 所 示 。 


Ts] C: pa chehhtdocs*shophadminiaddleibie. php -Dx 


增加 类 别 
Bem: — 


ky Qj 100€ — [543 x dde 3 K / 1 $0. Hipi Giz) 


图 10-14 IMAI PETRI ER SCA 


(20 在 单 击 “ 增 加 ” 投 钮 的 时 候 ， 要 先进 行 表单 验证 ， 再 提交 到 saveaddleibie.php 页 
面 ， 进 行 插 入 数据 库 的 操作 。 该 页面 的 代码 如 下 : 


$leibie=$_POST[leibie]; 
include("conn/conn.php"); 
$sql2mysql query("'select * from tb type where typename-"" $leibie.""",Sconn); 
$info2mysql fetch, array(Ssql); 
if(Sinfo!-false)( 

echo" &script»alert( 122351] 52$ 1f 1E V );window.location.href-'addleibie.php'; «/script^ "; 
exit; 
HM/ 判 断 类 别 是 否 存 在 
mysql query("insert into tb type(typename) values ('Sleibie")",$Sconn); 
echo"&script^alert( Jr PZS VJ] !');window.location.href-'addleibie.php'; «/script^ "; 
S/A 3,4] 48 IH] addleibie.php 


在 编写 的 时 候 要 充分 考虑 到 类 别 是 否 已 经 存在 ， 因 此 需要 加 入 一 个 判断 环节 。 


Section 


qug 用 户 管理 功能 


用 户 管 理 功 能 与 前 人 台 的 用 户 注册 功能 互相 呼应 ， 对 于 一 个 购物 网 站 来 说 ， 一 个 完善 的 用 
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户 管理 系统 一 定 要 有 -一 个 功能 比较 强大 的 用 户 后 台 管理 ， 实 例 中 制作 了 “会 员 管理 “留言 


管理 人 “更 改 管 理 员 ”3 个 菜单 项 ， 本 小 节 陨 介绍 这 几 个 小 功能 的 实现 方法 。 


10.3.1 enters 


会 员 的 管理 功能 主要 是 指 能 够 在 后 台 实 现 会 员 的 删除 ， 对 一 些 会 员 能 够 实现 “冻结 ”的 操 
作 ， 保 留 会 员 的 信息 但 苯 止 其 在 前 人 台 进 行 购物 及 发 言 。 会 员 管理 功能 的 首页 为 edituserphp, il 
作 的 详细 步骤 如 下 。 

(1) 使 用 Dreamweaver 设计 的 会 员 管 理 页 面 如 网 10-15 所 示 。 


Ts] C: Màpachesht docssshophadmin'edituser. php -DHx 


ER font.css conn. php 


:本 站 共有 注册 用 户 Ji 位 每 页 显示 Gu) pr e Gu) v/dt gu) vr Hp) 4 « du) Gu) Gu) Guy 


` 
- 
` 
` 


k| Qj 100& 668 x 222 T K / 1 $6 Mpi (GB2312) 


(20 单 击 “ 删 除 ” 复 选 按 钮 ， 再 单 击 “ 删 除 选项 ”时 ， 能 够 提交 表单 到 deleteuserphp 
动态 页 和 面 ， 即 可 实现 会 员 数 据 删 除 的 操作 。 访 页 面 的 程序 如 下 : 


<?php 

include("conn/conn.php"); 

while(list($name,$value)=each($_POST)) 
{ 


mysql_query("delete from tb_user where id=".$value. 


"tt 


,$conn); 
mysql query(" delete from tb pingjia where userid=". $value.""); 


"tt 


mysql query("delete from tb leaveword where userid-".$ value." ",$conn); 


j 
header("location:edituser.php"); 
T> 


注意 : 
在 删除 会 员 的 时 候 ， 同 样 要 注意 删除 数据 库 中 tb user. tb pingjia. tb leaveword 这 3 个 
数据 表 中 所 有 关联 的 数据 ， 删 除 成 功 后 要 返回 会 员 管 理 主页 面 。 


(3) 在 单 击 “ 答 看 详细 ”链接 后 ， 将 打开 对 用 户 信息 “冻结 ”和 “解冻 ”的 页 面 looku 
serinfo.php， 访 得 看 用 户 信息 的 页 面 如 网 10-16 所 示 。 


MD PIDE. $102 GIENSUEULLEZ 


四 C:\ipache\htdocs\shop\admin\lookuserinfo. php -Bx 


"SS font. ess conn. php 


M] 


u-» Fam 


eus 


本 se 
2 
”人 

。 Ji 


n= Tam 


body? Kn T01 x 291v 5 K / 1 秒 | 简体 中 文 582312) 
10-16. 会 看 用 户 信 息 页 面 


编写 实现 对 用 户 信 息 “ 冻 结 ” 和 “解冻 ”的 程序 其 实 非常 人 镜 单 ， 只 要 赋值 为 0 或 者 1 来 
区 分 古人 盏 冻结 ， 在 俘 询 会 员 信息 的 时 候 残 能 够 按 俘 询 是 0 或 者 是 1 来 给 会 员 权 限 。 代 码 如 下 : 


<?php 
$sql=mysql_query("select * from tb_user where id=".$id."",$conn); 


$info=mysql_fetch_array($sql); 
if($info[dongjie]==0) 
{ 
echo "冻结 该 用 户 "; 
} 


else 


{ 
echo "解除 冻结 "; 
} 


?> 


10.3.2 


当 会 员 在 购物 时 过 到 问题 ， 可 以 直接 通过 留言 功能 和 管理 员 进 行 沟通 ， 后 台 管 理 员 要 及 
时 浏览 会 员 的 留言 并 进行 相应 的 处 理 ， 对 于 一 n 的 留言 可 以 直接 删除 。 用 于 留言 管理 的 
页 面 古 lookleaveword.php. 

C1) 制作 的 留言 处 理 页 面 lookleaveword.php 效果 如 图 10-17 所 示 。 


T C: Apachexht docsVshophadminllookleaveword. php - 口 X 


HIRED font. css conn. php function. php 


R] Q 100%  , T60x 2257 T K / 1 秒 简体 中 交 (6B2312) — 


10-17 留言 处 理 页 面 
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(2) 该 页 面 主要 是 从 数据 库 中 查询 所 有 的 留言 并 显示 在 网 页 中 ， 在 单 击 “ 删 除 ” 复 选 按 
钮 ， 再 单 击 “ 删 除 选 项 ”时 ， 提 交 表 单 信息 至 deleteleaveword.php 页 面 进行 删除 数据 的 操 
作 。 实 现 删 除 的 代码 如 下 : 


<?php 

include("conn/conn.php"); 
while(list($name,$value)=each($_POST)) 
{ 


mysql_query("delete from tb_leaveword where id= 


j 


header("location:lookleaveword.php"); 
?>// 删 除 成 功 返 回 lookleaveword.php 


ORE 更 改 管理 员 功 能 


网 站 开发 者 在 开发 时 一 般 使 用 的 用 户 名 和 密码 都 是 admin， 在 提交 给 网 站 管理 员 时 ， 为 
了 安全 起 见 ， 管 理 员 要 能 够 实现 后 合 管理 员 的 用 户 名 和 蜜 但 的 修改 。 实 现 该 功能 的 页 面 是 
changeadmin.php. 

CG) 制作 的 更 改 管理 员 页 面 changeadmin.php 的 效果 如 图 10-18 所 示 。 


111 nt 


.$value.""",$conn); 


b C:XApache'ht docs*shop*adminkchangeadmin. php - 0X 


body> (k]éy Q 100$  ~v|T51 x 1534 5 K / 1# pX (682312) 


图 10-18 网 站 管理 员 后 台 修 改 页 面 


(20 输入 新 旧 管 理 员 的 用 户 名 和 密码 ， 再 单 击 “ 更 改 ” 按 钮 ， 可 以 提交 表单 进行 验证 ， 
然后 提交 到 savechangeadmin.php 进行 数据 更 新 的 操作 。 实 现 的 代码 如 下 : 


<?php 
$n0=$_POST[n0]; 
$n1=$_POST[n1]; 
$p0=md5($_POST[p0]); 
$pl=trim($_POST[p1); 


include("conn/conn.php"); 


$sql=mysql_query("select * from tb admin where name='".$n0."",$conn); 
$info2mysql fetch, array(Ssql); 
if(Sinfo--false) 


+10% QGiülBs/ ESSE 


echo "«script»alert( Af 4E 5 H] J^? );history.back(;«/script» "; 
exit; 


j 


else © 
l v 


if(Sinfo[pwd]--$p0) 


{ 
if($n1!="") 
{ 
mysql_query("update tb admin set name='".$n1.""where id=".$info[id]." ",$conn); 
j 
if($pl fm) 
{ 
$pl=md5($p1); 
mysql query("update tb admin set pwd='".$p1."" where id=".$infoļ[id]."",$conn); 
j 
j 
else 
{ 
echo "<script>alert(' JR 2 144i ACE VA); history.back(); «/script? "; 
exit; 
j 
j 
echo "«script»alert(' E MI ');history.back();X/script? "; 
2» 


该 程序 首先 对 管理 员 的 用 户 名 进行 验证 ， 判 断 正 确 后 才 进 行 数 据 更 新 ， 并 显示 更 新 


订单 管理 功能 


订单 管理 功能 是 购物 网 站 的 重点 ， 对 于 网 站 管理 员 而 言 ， 一 定 要 及 时 登录 后 人 台 对 订单 进 


行 管理 并 及 时 发 货 。 实 例 在 登录 后 台 时 把 订单 管理 的 功能 放 到 了 玖 认 打 开 的 页 面 ， 主 要 包 丘 
了 “编辑 订单 ”和 “查询 订单 ”2 个 小 功能 。 下 面 就 分 别 做 介绍 。 


编辑 订 蛙 功能 


所 谓 的 编辑 订单 是 指 管理 员 在 登录 后 台 后 ， 对 会 员 提 交 的 订单 进行 “已 收 蒜 ”“ 已 发 


货 ”“ 已 收 货 ” 等 验证 ， 同 时 要 及 时 打印 出 网 上 订单 并 提交 给 公司 进行 发 货 处 理 。 编 辑 订 单 
的 主页 是 lookdd.php。 

(1) 设计 的 lookdd.php 页 面 的 效果 如 图 10-19 所 示 。 该 页 面 只 有 简单 的 订单 信息 功能 ， 
只 要 从 数据 库 中 查询 订单 进行 显示 即 可 。 
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四 C:\Apache\htdocs\shop\admin\lookdd. php LX 


WT pa s HDD m ug o RE. 


T50 x 263v 8 K / 1 秒 | 简体 中 文 (5B2312) 


10-19 ”编辑 订单 页 面 


(2) 设计 的 第 二 步 陨 是 实现 单 击 “ 奉 看 ”按钮 时 ， 能 调 出 订单 的 详细 内 容 showdd.php 


和 面 ， 并 能 进行 打印 。 在 网 上 浏览 的 效果 如 图 10-20 所 示 。 


73 nttp://127.0.0.1 — 商品 订单 - Nicrosoft Internet Explorer m fx) 


订单 号 : 2011062801112144 | 打印 预览 | | 打印 


刘 小 小 
: “北京 朝阳 戏 桥 12 号 
101121 电 话 : 13800138000 
designemü153. com 
普通 平邮 支付 方式 : 建设 银行 汇款 
汇款 时 注 明 您 的 订单 号 ?汇款 后 请 及 时 联系 我 们 ， 


8D Internet 


10-20 ”订单 详细 内 容 页 面 


showdd.php 页 面 中 调用 函数 实现 打印 的 功能 ， 具 体 的 代码 如 下 : 


<html> 

<head> 

«meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
«title» rj mii] H.«/title» 

<link rel="stylesheet" type="text/css" hrefz"css/font.css"» 
<style type="text/css"> 

<l-- 

@media print{ 

div {display:none } 

j 

.Style3 (color: #990000} 

2s. 

</style> 


省 | 二 请 汉 PHP 网 上 购物 系统 后 台 开 发 


</head> 
<?php 
include("conn/conn.php"); 


$id=$_GET[id]; | 
$sql2mysql query('select * from tb dingdan where id='".$id."'"",$conn); c 
$info2mysql fetch array($sql); | 
$spc-S$info[spc]; 
$slc-Sinfo[slc]; 
$arraysp-explode(" Q ",$spc); 
$arraysl=explode(" @",$slc); 
2» 
«body topmargin-z"0" leftmargin="0" bottommargin= "0 > 
<p>&nbsp;</p> 
<table width="600" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr align="center" bgcolor="#FFCF60"> 
«td height="20" colspan="2" bgcolor="#0099FF"> 简 总 订单 </td> 
</tr> 
<tr> 
«td width="448" height="20"> 订 单 写 : <?php echo $info[dingdanhao];?></td> 
«td width="152"><div align="right"> 
<script> 
function prn()[ 
document.all. WebBrowserl.ExecWB(7,1); 
j 
</script> /实现 打印 预览 的 功能 
<object  ID2'WebBrowserl' WIDTH=0  HEIGHT-0 | CLASSID-'CLSID:8856F961-340A- 
11D0-A96B-00C04FD705A2^» </object> 
«input type="button" valuez"$T Eft v" classz"buttoncss" onClicke"prn()"» &nbsp; 
«input type="button" value-"1] ED" class-"buttoncss" onClick-"window.print()"» «/div» «/td»//S: B 1T 
印 的 功能 


</tr> 
<tr> 
«td height="20" colspan="2"> 商 品 列 表 ( 如 下 ): </td> 
</tr> 
</table> 


«table width="500" height="60" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td bgcolor="#666666"><table width="500" border="0" align="center" cellpadding="0" 
cellspacing="1"> 
<tr bgcolor="#0099FF"> 
<td width="153" height="20"> 商 品名 称 </td> 
«td width="80"> 市 场 价 </td> 
«td width="80"> 会 员 价 </td> 
«td width="80"> 数 量 </td> 
«td width="101"> 小 计 </td> 
</tr> 
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<?php 
$total=0; 
for($i=0;$i<count($arraysp)-1;$i++){ 
if($arraysp[$1]!=""){ 
$sqgl12mysgql. query("select * from tb_shangpin where id= 


111 nt 


.Sarraysp[$i].""", Sconn); 
$infol-mysql fetch, array($sql1); 
$total-$total---Sarraysl[$1]*Sinfol [huiyuanjia]; 
2 
«tr bgcolor="#FFFFFF"> 
«td height="20"><?php echo S$infol [mingcheng];?» «/td» 
«td heightz"20"* «?php echo S$infol [shichangjia];?» </td> 
«td heightz"20"* «?php echo S$infol [huiryuanjia];?» </td> 
«td heightz"20"* «?php echo S$arraysl[$1i];?» «/td» 
«td heightz"20"* «?php echo S$arraysl[$1] *Sinfol [huiyuanjia];?» </td> 
</tr> 
<?php 
j 
} 
2> 
<tr bgcolor="#FFFFFF"> 
<td height="20" colspan="5"> 
总 计 费 用 :<?php echo $total;?> 
</td> 
</tr> 
</table> </td> 
</tr> 
</table> 
«table width="460" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
«td width="81" height="20"> 下 单 人 : </td> 
«td colspan="3"><?php echo Sinfo[xiadanren];?» </td> 
</tr> 
<tr> 
«td height="20"> 收 贷 人 : </td> 
<td height="20" colspan="3"><?php echo $info[shouhuoren];?> </td> 
</tr> 
<tr> 
«td height="20"> 收 货 人 地 址 : </td> 
«td height="20" colspanz"3"» «?php echo $info[dizhi];?> </td> 
</tr> 
<tr> 
«td height="20"> 邮 &nbsp;&nbsp; 编 : </td> 
«td width="145" height="20"><?php echo $info[youbian];? ></td> 
«td width="66"> 电 &nbsp;&nbsp; 话 : </td> 
«td widthz" 158"» «?php echo $info[tel];?></td> 
</tr> 
<tr> 


cc 840€ QUNETECLLEZ: 


«td heightz" 20" * E-mail: «/td* 
«td height" 20" «?php echo Sinfo[email|;?» </td> 
«td heightz"20"» &nbsp;«/td» 
«td heightz"20"» &nbsp;«/td» 
</tr> 
<tr> 
«td height="20"> 送 货 方式 : </td> 
<td height="20"><?php echo $info[shff];?></td> 
«td height="20"> 文 付 方式 : </td> 
«td height="20"><?php echo $info[zfff];?> </td> 
</tr> 
<tr> 
«td height="20" colspan="4"><span class-"inputcssnull"» 7| 3I] 33: HH A85 HP] V] Hoy 1 TE UR ie Jc 
时 联系 我 们 ! «/span» «/td» 
</tr> 
<tr> 
«td height="20">&nbsp; </td> 
«td height="20"><div align="center"><input type="button" onClick="window.close()”value=" 关 
闭 窗口 " class="buttoncss"></div></td> 
«td height="20"> 创 建 时 间 : </td> 
«td height="20"><?php echo $info[time];?> </td> 
</tr> 
</table> 
</body> 
</html> 


(3) 要 实现 订单 的 网 上 处 理 ， 单 击 “ 执 行 ”按钮 即 可 以 打开 orderdd.php 页 面 ， 进 行 订单 
的 处 理 。 其 中 包括 了 “已 收 款 入 “已 发 货 和 “已 收 货 ”3 个 复 选 按钮 ， 对 其 进行 相应 的 处 理 ， 
如 图 10-21 所 示 。 


T C: XÀpachehht docskshopkadminkorderdd. php -Dx 


Pm font.css conn. php 


R| Q 1008 4 TE5 x 434v 98 K / 1 秒 简体 中 交 (6B2312) 


10-21 执行 订单 页 面 
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(4) 单 击 “修改 ”按钮 即 提 交 表 到 saveorder.php 进行 修改 数据 的 保存 ， 有 具体 的 代码 如 下 : 


<?php 
$ysk=$_POST[ysk]."&nbsp;"; 
$yfh=$_POST[yfh]." &nbsp;"; 
$ysh=$_POST[ysh]."&nbsp;"; 
$zt=""; 
if($ysk!="&nbsp;"){ 
$zt.=$ysk; 
j 
if(Syfh!2"&nbsp;")( 
$zt.-$yfh; 
j 
if($ysh!="&nbsp;"){ 
$zt.=$ysh; 
j 
if((Sysk--"&nbsp;")&&(Syfh--"&nbsp;")&&(Sysh--"&nbsp;"))( 
echo "<script>alert(' 请 选择 处 理 状 态 !"):history.back();</script>"; 
exit; 
j 


include("conn/conn.php"); 


11111 


$sql3=mysql_query("select * from tb_dingdan where id='".$_GET[id]."",$conn); 
$info32mysql fetch array($sq13); 
if(trim($info3[zt]) 2" Zk f EFE fn] Rb E") ( 


$sql2mysql query("select * from tb dingdan where id='".$_GET[id]. 


nt 


,$conn); 
$info=mysql_fetch_array($sql); 

$array=explode(" 9 ",Sinfo[spc]); 

$arraysl-explode("  " Sinfo[slc]); 


for($i-0;$i«count(Sarray);$i--4-)( 
$id-$array [$1]; 
$num-$arraysl[$i]; 


111 "nt. ' 


mysql query("update tb shangpin set cishu-cishu- ".$num." ,shuliang-shuliang-"".$num." 
where 1d="".$id.""",$conn); 
j 
j 
mysql query("update tb dingdan set zt-'".Szt." where id2".$ GET[id].""",Sconn); 
header("location:lookdd.php"); 


?> 


通过 上 述 4 个 步骤 的 设计 ， 后 台 的 订单 编辑 功能 即 开发 完成 . 
”查询 订单 功能 


在 网 站 运营 一 段 时 间 后 ， 网 上 的 订单 会 越 来 越 多 ， 也 经 营 会 遇 到 会 员 会 询 订单 的 事情 ， 
网 站 管理 员 同 样 也 需要 一 个 订单 后 人 台 奏 询 功 能 ， 才 能 方便 地 找到 相应 的 订单 。 实 例 奋 询 和 显 


n 


Jude $105 GD 于 二 到 


"NER E Re HI vr. BI finddd.php. 
CDD 制作 的 finddd.php 页 面 效果 如 图 10722 所 示 。 


四 C: XÀpache*htdocskshopNadminkfinddd. php mir 


"hat font ess conn. php 


body? pi R] Q 100$  . T36 x 249v 7K71 秒 | 简体 中 文 682312) 


10-22 ”查询 订单 页 面 


(2) 核心 程序 如 下 : 


<html> 
<head> 
«meta http-equiv="Content-Type" content-"text/html; charset=gb2312"> 
«title» 1] ££. rif «/title» 
<link rel="stylesheet" type="text/css" hrefz"css/font.css"» 
</head> 
<?php 
include("conn/conn.php"); 
?> 
<body topmargin="0" leftmargin="0" bottommargin="0"> 
<p>&nbsp;</p> 
<table width="550" border="0" align="center" cellpadding="0" cellspacing="0"> 


<tr> 
«td height="20" bgcolor="#0099FF"><div align="center" style="color: #FFFFFF"> 订 单 查 
询 </div></td> 
</tr> 
<tr> 


<td heightz"50"  bgcolorz'2555555"»«table width="550"  height2"50" border= 0" 
align="center" cellpadding-"0" cellspacing= 1] > 
«tr? 
«td bgcolor="#FFFFFF"> 
«table width" 550" heightz" 50" borderz"0" align="center" cellpadding="0" cellspacingz"0"» 
<script language-"javascript"» 
function chkinput3(form) 


if((form.username.value--" ")&&(form.ddh.value--"")) 


{ 
alert(" 请 输入 下 订单 人 或 订单 写 "); 


form.username.select(); 
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return(false); 


j 


return(true); 


</script> 
<form name="form3" method="post" action="finddd.php" onSubmit="return 
chkinput3( this)"> 
<tr> 
<td height="25"><div align="center"> 下 订单 人 姓名 :<input type="text" name= 
"username" class-"inputcss" size-"25" > 
订单 号 :<input type="text" name-"ddh" size="25" class-"inputcss" ></div> 
</td> 
</tr> 
<tr> 
<td height="25"> 
<div align="center"> 
<input type="hidden" value="show_find" name="show_find"> 
<input name-"button" type="submit" class-"buttoncss" id="button" 


value=" fr 找 "> 
</div></td> 
</tr> 
</form> 
</table></td> 
</tr> 
</table></td> 
</tr> 
</table> 
<table width="550" height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td> &nbsp;</td> 
</tr> 
</table> 
<?php 


if($_POST[show_find]!=""){ 
$username-trim($ POST[username]); 
$ddh-trim($ POST[ddh]); 
if(Susername--"")( 
$sgl2mysql query('select * from tb dingdan where dingdanhao="".$ddh."",$conn); 


j 
elseif($ddh--"")( 
$sgl2mysql query('select * from tb dingdan where xiadanren='".$username."",$conn); 
j 
else{ 


111 


$sqgl2mysql query("'select * from tb dingdan where xiadanren='".$username."'and 


dingdanhao=".$ddh."",$conn); 
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} 
$info2mysql fetch, array($sql); 
if(Sinfo--false)( 
echo "<div algin='center> 对 不 起 ,没有 得 找到 该 订单 !</div>"; M 
/ D 
else { 
1> 
<table width="550" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
«td height="20" bgcolor="#0099FF"><div align="center" style="color: #FFFFFF"> 查 询 结 
果 </div></td> 
</tr> 
<tr> 
<td heightz"50"  bgcolorz'2555555"»«table width="550" height="50" border="0" 
align="center" cellpaddingz"0" cellspacing="1"> 
<tr> 
<td width="77" height="25" bgcolor="#FFFFFF"><div align="center"> i| 单 5 
</div></td> 
«td width="77" bgcolor="#FFFFFF"><div align="center"> F £P? </div></td> 
«td width="77" bgcolor="#FFFFFF"> <div align="center"> i] $$ A </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 47 4i yF </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align2"center"» ] 3X 7j 3X </div></td> 
«td widthz"77" bgcolorz" 4FFFFFF"» «div align="center"> 1 5X 7j 3X </div></td> 
«td width='"77" bgcolor="#FFFFFF"><div align="center"> 1] Fs «/div» «/td» 
</tr> 
<?php 
do( 
jo 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[dingdanhao];?» </div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[xiadanren];?></div> </td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[shouhuoren];? ></div> </td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[total];2» </div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[zfff];?» </div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[shff];?> </div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[zt];?» </div></td> 
</tr> 
<?php 
)while(Sinfo2mysgql. fetch. array ($sql)); 


PHP 


?> 


</table></td> 
</tr> 
</table> 
<?php 


10.5 = a E 管理 功能 日 上 


信息 管理 功能 是 指 在 网 站 后 台 实 现 新 闻 、 用 户 的 商品 评价 等 相关 的 管理 操作 ， 本 实例 制 
作 了 管理 公告 、 发 布 公告 、 管 理 评价 3 个 功能 ， 通 过 这 3 个 功能 ， 能 够 实现 整个 网 站 的 即时 
公告 发 布 、 公 告 修改 ， 以 及 商品 评论 的 编辑 修改 功能 。 


管理 公告 功能 


管理 公告 功能 是 指 可 以 在 后 台 对 发 布 的 公告 进行 修改 和 删除 。 管 理 公 告 的 页 面 为 
admingonggao.php. 
CI) 制作 的 管理 公告 页 面 admingonggao.php 效果 如 图 10-23 所 示 。 


四 C: AApachexht docssshop*adminiadmingonggao. php -0X 


HS font.css conn. php 


[RS Q 1008 vv|753 x 268. TK / 14 füffchir(oB2312) — - 


10-23 ”管理 公告 页 面 


(2) 单 击 “ 选 择 ” 复 选 按 钮 ， 再 单 击 “删除 所 选 ” 按 钮 ， 可 以 提交 表单 到 deletegonggao.php， 
进行 删除 公告 的 操作 ， 代 码 如 下 : 


<?php 
include("conn/conn.php"); 
while(list($name,$value)=each($_POST)) 


{ 
mysql_query("delete from tb_gonggao where id= 


"wf nt 


.$value.""",$conn); 


QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


MEME EE $102 PHP 网 上 购物 系统 后 台 开发 


j 
header("location:admingonggao.php"); 
2» 


(3) 单 击 “ 人 修改” 文字 链接 ， 可 以 打开 editgonggao.php 页 面 进行 公告 的 编辑 操作 ， 访 页 
面 如 图 10-24 所 示 。 


T) C: XÀpache^ht docsshop*adminkedi t gonggao. php = 0x 


Hau font. css conn. php 


z > 
body? Kr) (R| Qj 1008  « T40 x 268v 4 K / 1 d^ 简体 中 交 (6B2312) — - 


10-24 修改 公告 页 面 


(4) 和 输入 修改 的 公告 主题 和 公告 内 容 ， 再 单 击 “ 更 改 ” 按 钮 ， 可 以 提交 表单 到 saveeditgonggao. 
Php， 进 行内 容 的 更 新 操作 ， 更 新 的 代码 如 下 : 


<?php 
$title-$ POST[title]; 
$content-$ POST[content]; 
include("conn/conn.php"); 


ntt 


,$conn); 


mysql query("update tb_gonggao set title='$title',content='$content' where id="".$_POSTI[id]. 
echo "<script>alert( 公 告 修改 成 功 !);history.backO;</Script> "; 
5 


10.5.2 


用 于 添加 新 的 公告 的 页 面 是 addgonggao.php， 实 现 的 方法 束 是 采集 公告 的 字段 进行 数据 
的 插入 操作 。 本 小 节 就 介绍 添加 新 公告 的 具体 方法 。 
(1) 添加 新 公告 页 面 addgonggao.php 如 图 10-25 所 示 。 


四 C:\Apache\htdocs\shop\admin\addEonEEao. php - 口 X 


HIED font. css 


All > 
[R| 江 Ql100% v|722 x 270v 4 K / 1 秒 MAPE 2312) — - 


10-25 ”添加 新 公告 页 面 


7PHP-^ 


(20 录入 完 主 题 和 内 容 ， 单 击 “ 添 加 ”按钮 ， 可 以 提交 表单 进行 验证 ， 并 提交 到 
savenewgonggao.php 负面， 进行 新 公告 的 保存 操作 。 实 现 的 代码 如 下 : 


<?php 
include("conn/conn.php"); 
$title-$ POST[title]; 
$content=$ POST[content]; 
$time-date("Y -m-j"); 
mysql query("insert into tb. gonggao (title,content,time) values ('Stitle','Scontent','Stime")",Sconn); 
echo "&script^alert( s A RJK ');history.back();«/script? "; 
2 


后 人 台 的 最 后 一 个 功能 是 管理 评价 功能 ， 通 过 管理 可 以 将 商品 的 一 些 负 面 信 息 进 行 删除 操 
作 。 管 理 评价 功能 的 页 面 是 editpinglun.php， 人 制作 的 方法 如 下 。 
(1) 编辑 用 户 评价 页 面 editpinglun.php 的 效果 如 图 10-26 所 示 。 


四 | C: \Apache\htdocs\shopadminieditpinglun. php = 0X 


a PME 


ky Q 1008 v TAT x 2009 T K / 1 秒 简体 中 六 (GB2312) 


10-26 ”编辑 用 户 评价 页 面 


(2) 通过 单 击 “ 查 看 ”文字 链接 ， 能 打开 Windows 窗口 显示 评价 的 详细 内 容 ， 实 现 的 
mE 


<?php 
include("conn/conn.php"); 
$sql=mysql_query("select count(*) as total from tb_pingjia ",$conn); 
$info-mysgl fetch, array($sql); 
$total-Sinfo[total]; 
if($total==0) 
echo "本 站 和 暂 无 用 户 友 表 评 论 !"; 
} 


else 


{ 


?> 


QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


省 | 二 请 汉 PHP 网 上 购物 系统 后 台 开 发 


<script ljanguage= javascrlpt > 
function openpj(id) 


{ 
window.open("lookpinglun.php?id="+id,"newframe","width=500,height=300,top=100,left=200,menubar G 


-no,toolbar-no,location-no,scrollbar-no,status-no"); 


j 


</script> 


(3) 单 击 “ 删 除 ” 复 选 按钮 ， 再 单 击 “ 删 除 选项 ”按钮 ， 可 以 提交 表单 全 删除 评价 的 页 
Ifi] deletepingjia.php， 该 页面 的 代码 如 下 : 


<?php 
include("conn/conn.php"); 
while(list($name,$value)=each($_POST)) 


{ 
$id=$value; 
mysql_query("delete from tb pingjia where id=".$id."",$conn); 


j 
header("location:editpinglun.php"); 
75 


通过 上 述 儿 大 后 合 管理 功能 的 开发 ， 读 者 可 以 发 现 使 用 PHP 进行 网 上 后 合 管理 系统 的 
开发 其 实 并 不 难 。 正 所 谓 “ 磨 思 不 误 砍 烷 工 ”， 在 开发 类 似 的 网 站 时 一 定 要 做 后 台 开 发 前 的 
架构 设计 ， 与 需求 方 沟通 到 位 ， 可 以 轻松 实现 网 站 的 开发 工作 。 


———— ————— ——— a RR E sr 


UG NX 7.5 完全 自学 手册 
书号 : 32379 定价 : 56.00 元 
作者 : 钟 日 铭 等 

本 书 以 UG NX 7.5 中 文 版 软件 为 操作 基 
础 ， 结 合 典 型 范例 循序 渐进 地 介绍 了 该 软件 的 
功能 和 实战 应 用 知识 。 本 书 知识 全 面 、 实 用 ， 


共 分 9 章 ， 内 容 包括 ，UG NX 7.5 入 门 简介 及 基 | 


本 操作 、 草 图 、 空 间 曲 线 与 基准 特征 、 创 建 实 


体 特征 、 特 征 操作 及 编辑 、 曲 面 建 模 、 装 配 设 | 


计 、 工 程 图 设计 、GC 工 具 箱 应 用 与 同步 建 模 。 


AutoCAD 2012 中 文 版 

入 门 。 进 阶 。 精通 第 2 版 
书号 : 34957 E: 52.00 元 
作者 : 钟 日 铭 等 

本 书 以 AutoCAD 2012 中 文 版 为 基础 , 结合 
软件 功能 和 特点 ， 循 序 渐进 地 介绍 了 AutoCAD 
入 门 、 进 阶 与 精通 的 应 用 知识 。 本 书 图 文 并 成 、 
结构 清晰 、 重 点 突出 、 实 例 典型 、 应 用 性 强 ， 


是 一 本 很 好 的 从 入 门 到 精通 的 学 习 教程 ， 适 合 | 
从 事 机械 设 计 、 建 筑 制图 、 电 气 绘图 、 广告 制 | 


作 等 工作 的 专业 技术 人 员 阅 读 。 


UG NX 7. 5 基础 应 用 与 
范例 解析 第 3 版 
书号 : 36423 定价: 59.80 元 
作者 : 李 志 尊 等 


本 书 介 绍 了 利用 UG NX 7.5 进行 实体 建 
模 、 装 配 建 模 、 工 程 制 图 、 运 动 仿真 以 及 有 限 


元 分 析 等 方面 的 内 容 。 本 书 的 写作 结合 了 作者 | 


多 年 来 在 机 械 设计 教学 和 科研 方面 的 经 验 ， 内 
容 选 取 适 当 ， 范 例 具 有 典型 的 代表 性 ， 叙 述 简 
Zo BARH, TAR. 


ET E LE 


SolidWorks 2011 机 械 设计 
完全 实例 教程 

书号 : 36514 定价: 62.00 元 
作者 : 张 忠 将 等 

本 书 紧 密 结合 实际 应 用 ， 以 众多 精彩 的 机 | 
械 设 计 实 例 为 引导 ， 详 细 介绍 了 SolidWorks 从 E 
模型 创建 到 出 工程 图 ， 再 到 模型 分 析 和 仿真 等 外 
的 操作 过 程 。 本 书 实例 涵盖 典型 机 械 零 件 、 输 
送 机 械 、 制 动机 械 、 农 用 机 械 、 紧 固 和 夹具 、 
传动 机 构 和 弹簧 / 控制 装置 等 的 设计 。 


ANSYS 13.0 与 HyperMesh 11.0 
联合 仿真 有 限 元 分 析 

书号 : 37170 E: 49.00 元 
作者 : 贺 李 平 等 

本 书 主 要 讲解 如 何 利 用 HyperMesh11.0 建 f 
立 高 质量 的 有 限 元 模型 ， 再 以 ANSYS13.0 作 为 | 
求解 器 来 解决 各 类 工程 问题 。 全 书 共 20 章 , 包 | 
含 了 Hyper Mesh 有 限 元 网 格 建 模 、ANSYS 单 元 | 
技术 、 装 配 体 连接 技术 、 瞬 态 动力 学 分 析 、 响 | 
应 谱 分 析 和 多 体 刚 .和 柔 系 统 分 析 等 内 容 。 | 


SolidWorks 2011 中 文 版 数字 样机 | 
技术 及 其 应 用 实例 〈 人 入 门 与 提高 ) | 
书号 : 36684 E: 79.80 元 

作者 : 印 会 朋 


本 书 按 “ 数 字样 机 ”和 “数字 样机 技术 ” | 
的 全 新 理念 编著 ， 系 统 讲述 了 SolidWorks 2011 | 
中 文 版 数字 样机 技术 及 其 应 用 实例 。 本 书 适合 | 
广大 从 事 数 字样 机 研发 的 从 业 人 员 阅 读 和 参 | 
考 , 也 可 作为 应 用 型 本 科 院 校 、 职业 技术 学 院 、| 
技师 学 院 和 高 级 技工 学 校 相关 课程 的 教材 或 参 | 
考 书 。 \ 


aries ded é3tvityeipralevitovbredesatavitredtyeioyéttv re 


追逐 App Store 的 脚步 
手机 软件 开发 者 创 富 之 路 


ISBN 978-7-111-35619 -6 定价: 49.00 元 
作者 : 项 有 建 


是 如 何 针对 现代 手机 软件 产品 进行 设计 ;介绍 
了 数字 产品 的 营销 方法 ， 特 别 是 如 何 针对 现代 
手机 软件 产品 进行 营销 的 方法 。 书 中 强调 了 用 
户 需求 以 及 竞争 两 个 设计 视角 , 介绍 了 “平台 辐 
射 原理 ”, 初步 解决 了 如 何 利 用 公式 化 的 方法 用 
平台 推广 产品 的 问题 。 


Windows Phone 7 完美 开发 征程 
ISBN 978-7-111-34043 -0 E: 45.00 元 
作者 : [UR 

本 书 以 全 新 的 Windows Phone 7 手机 应 用 


程序 开发 为 主题 ， 采 用 理论 和 实践 相 结合 的 方 | 
法 ， 由 浅 入 深 地 讲述 了 新 平台 的 基础 架构 、 开 
发 环境 、 图 形 图 像 处 理 、 数 据 访问 、 网 络 通信 
等 知识 点 。 最 后 通过 较为 完整 的 实战 演练 ， 帮 
助 读者 更 快 地 掌握 项 目 开发 的 各 个 技术 要 点 ， 
使 读者 能 够 尽快 投入 到 实际 项 目的 开发 。 


从 实例 走 进 OPhone 世 界 
ISBN 978-7-111-33030 -1 定价: 45.00 元 
作者 : 周 轩 

本 书 从 一 个 开发 者 的 角度 出 发 ， 介 绍 了 
OPhone/Android 系 统 的 基础 知识 和 开发 技巧 ， 
详细 讲解 了 无 线 通 信 、 娱 乐 游 戏 、 移 动 生活 、 
OPhone 特 色 应 用 等 多 种 类 型 程序 的 开发 流程 
和 方法 ; 通过 介绍 系统 上 自 带 源 代码 实例 ， 为 读 
者 提供 参考 资料 和 分 析 素 材 。 环 境 ， 并 配 有 大 
量 插图 和 代码 注释 ， 为 自学 者 提供 了 方便 。 


本 书 介绍 了 如 何 进行 软件 产品 设计 , 特别 | 
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Android 开发 案例 驱动 教程 
ISBN 978-7-111-35004 -0 ”定价 : 69.80 元 
作者 : 关东 升 

本 书 旨 在 帮助 读者 全 面 掌握 Android 开 发 | 
技术 ， 能 够 实际 开发 Android 项 目 。 本 书 全 面 介 | 
绍 了 在 开源 的 手机 平台 Android 操 作 系统 下 的 | 


应 用 程序 开发 技术 ， 包 括 UI、 多 线程 、 数 据 存 | 
储 、 多 媒体 、 云 端 应 用 以 及 通信 应 用 等 方面 。 | 
本 书 采用 案例 驱动 模式 展开 讲解 ， 既 可 作为 高 | 
等 学 校 的 参考 教材 , 也 适合 广大 Android 初 学 者 | 
和 Android 应 用 开发 的 程序 员 参 考 。 | 


ed 


从 灵感 到 实现 一 一 打造 你 

第 一 个 Windows Phone 7. 5 应 用 
ISBN 978-7-111-37452-7 EW: 56.00 元 
作者 : 李 永 伦 | 
本 书 讲述 了 一 个 真实 应 用 的 开发 故事 , 为 | 
你 呈现 一 个 完整 的 开发 过 程 ， 包 括 安装 环境 、 | 
需求 分 析 、 原 型 设计 、 功 能 开发 、 应 用 测试 和 | 


错误 修正 。 本 书包 含 了 详细 的 可 操作 的 步骤 ， 


“手把手 教 你 实现 相关 功能 ， 并 且 留 下 一些 作业 | 


给 你 练 手 , 以 便 巩固 这 节 课 学 到 的 知识 和 技术 。 | 


Qt 开发 Symb ian 应 用 权威 指南 
ISBN 978-7-111-36089 -6 FET: 45.00 元 
作者 : Fitzek 等 译 者 : DevDiv 移动 开发 社区 | 

本 书 主要 是 向 读者 介绍 如 何在 Symbian 上 | 
快速 有 效 地 创建 Qt 应 用 程序 。 全 书 共 分 7 章 , 包 | 
括 开发 入 门 、Qt 概 述 、Qt Mobility APIS、 类 Qt | 
移动 扩展 、 Qt 应 用 程序 和 Symbian 本 地 扩展 、 | 
Qt for Symbian 范 例 。 | 

本 书 可 作为 移动 设备 开发 领域 的 初学 者 和 | 
专业 人 员 的 参考 用 书 ， 也 可 作为 手机 开发 基础 | 
课程 的 教材 。 | 


机 工 出 版 社 . 计算 机 分 社 书 友 会 邀请 
尊敬 的 读者 : 


感谢 您 选择 我 们 出 版 的 图 书 ! 我 们 愿 以 书 为 媒 ， 与 您 交 朋 友 ， 做 朋友 ! 我 们 诚挚 地 邀 
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ee D e a (如: 图 形 图 
像 类 ， 软 件 开发 类 ， 办 公 应 用 类 ) 
联系 方式 
通信 地 址 : 北京 市 西城 区 百 万 庄 大 街 22 号 计算 机 分 社 联系 电话 : 010-88379750 
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